// ***********************************************
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//

Cypress.Commands.add("login", () => {
  cy.getCookie("budibase:auth").then(cookie => {
    // Already logged in
    if (cookie) return

    cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
    cy.contains("Create Test User").click()
    cy.get("input")
      .first()
      .type("test@test.com")

    cy.get('input[type="password"]').type("test")

    cy.contains("Login").click()
  })
})

Cypress.Commands.add("createApp", name => {
  cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
  // wait for init API calls on visit
  cy.wait(100)
  cy.contains("Create New Web App").click()
  cy.get("body")
    .then($body => {
      if ($body.find("input[name=apiKey]").length) {
        // input was found, do something else here
        cy.get("input[name=apiKey]")
          .type(name)
          .should("have.value", name)
        cy.contains("Next").click()
      }
    })
    .then(() => {
      cy.get(".spectrum-Modal")
        .within(() => {
          cy.get("input")
            .eq(0)
            .type(name)
            .should("have.value", name)
            .blur()
          cy.contains("Next").click()
          cy.get("input")
            .eq(1)
            .type("test@test.com")
            .blur()
          cy.get("input")
            .eq(2)
            .type("test")
            .blur()
          cy.contains("Submit").click()
        })
        .then(() => {
          cy.get("[data-cy=new-table]", {
            timeout: 20000,
          }).should("be.visible")
        })
    })
})

Cypress.Commands.add("deleteApp", name => {
  cy.visit(`localhost:${Cypress.env("PORT")}/builder`)
  cy.get(".apps").then($apps => {
    cy.wait(1000)
    if ($apps.find(`[data-cy="app-${name}"]`).length) {
      cy.get(`[data-cy="app-${name}"]`)
        .contains("Open")
        .click()
      cy.get("[data-cy=settings-icon]").click()
      cy.get(".spectrum-Dialog").within(() => {
        cy.contains("Danger Zone").click()
        cy.get("input")
          .type("DELETE")
          .blur()
        cy.contains("Delete Entire App").click()
      })
    }
  })
})

Cypress.Commands.add("createTestApp", () => {
  const appName = "Cypress Tests"
  cy.deleteApp(appName)
  cy.createApp(appName, "This app is used for Cypress testing.")
})

Cypress.Commands.add("createTestTableWithData", () => {
  cy.createTable("dog")
  cy.addColumn("dog", "name", "Text")
  cy.addColumn("dog", "age", "Number")
})

Cypress.Commands.add("createTable", tableName => {
  // Enter table name
  cy.get("[data-cy=new-table]").click()
  cy.get(".spectrum-Modal").within(() => {
    cy.get("input")
      .first()
      .type(tableName)
      .blur()
    cy.get(".spectrum-ButtonGroup")
      .contains("Create")
      .click()
  })
  cy.contains(tableName).should("be.visible")
})

Cypress.Commands.add("addColumn", (tableName, columnName, type) => {
  // Select Table
  cy.contains(".nav-item", tableName).click()
  cy.contains("Create column").click()

  // Configure column
  cy.get(".spectrum-Modal").within(() => {
    cy.get("input")
      .first()
      .type(columnName)
      .blur()

    // Unset table display column
    cy.contains("display column").click({ force: true })
    cy.get("select").select(type)
    cy.contains("Save").click()
  })
})

Cypress.Commands.add("addRow", values => {
  cy.contains("Create row").click()
  cy.get(".spectrum-Modal").within(() => {
    for (let i = 0; i < values.length; i++) {
      cy.get("input")
        .eq(i)
        .type(values[i])
        .blur()
    }
    cy.get(".spectrum-ButtonGroup")
      .contains("Create")
      .click()
  })
})

Cypress.Commands.add("createUser", (email, password, role) => {
  // Create User
  cy.contains("Users").click()
  cy.contains("Create user").click()
  cy.get(".spectrum-Modal").within(() => {
    cy.get("input")
      .first()
      .type(email)
      .blur()
    cy.get("input")
      .eq(1)
      .type(password)
      .blur()
    cy.get("select")
      .first()
      .select(role)

    // Save
    cy.get(".spectrum-ButtonGroup")
      .contains("Create User")
      .click()
  })
})

Cypress.Commands.add("addComponent", (category, component) => {
  if (category) {
    cy.get(`[data-cy="category-${category}"]`).click()
  }
  cy.get(`[data-cy="component-${component}"]`).click()
  cy.wait(1000)
  cy.location().then(loc => {
    const params = loc.pathname.split("/")
    const componentId = params[params.length - 1]
    cy.getComponent(componentId).should("exist")
    return cy.wrap(componentId)
  })
})

Cypress.Commands.add("getComponent", componentId => {
  return cy
    .get("iframe")
    .its("0.contentDocument")
    .should("exist")
    .its("body")
    .should("not.be.null")
    .then(cy.wrap)
    .find(`[data-component-id=${componentId}]`)
})

Cypress.Commands.add("navigateToFrontend", () => {
  cy.contains("design").click()
})

Cypress.Commands.add("createScreen", (screenName, route) => {
  cy.get("[data-cy=new-screen]").click()
  cy.get(".spectrum-Modal").within(() => {
    cy.get("input")
      .eq(0)
      .type(screenName)
      .blur()
    if (route) {
      cy.get("input")
        .eq(1)
        .type(route)
        .blur()
    }
    cy.contains("Create Screen").click()
  })
  cy.get(".nav-items-container").within(() => {
    cy.contains(route).should("exist")
  })
})