We're considering adding some new helper commands related to QDialog
function closeDialogViaEscKey () {
// Official way to escape `within` context
// https://docs.cypress.io/api/commands/within#Temporarily-escape
return cy.root().closest('body').type('{esc}')
}
Limitation: this only works in withinDialog context, as when using it outside it .root() will yeld "html" tag and Cypress won't be able to find anything with .closest('body') since it only searches upwards
We should find a way to make it work both inside and outside a within context
I tried with cy.window() and cy.document() already, which I recalled worked fine in the past, but it seems like they changed that behavior
Maybe by using the Cypress.$('body') shortcut that we already use in portal-related commands?
Even if it's an internal and undocumented feature AFAIK
function closeDialogViaBackdrop () {
return cy.get('.q-dialog__backdrop').click({ force: true })
}
assertPersistentDialogExists
function assertPersistentDialogExists () {
cy.get('.q-dialog').should('not.have.attr', 'aria-modal', 'false')
}
This should be called automatically after the callback function of withinDialog completes, if persistent is set to true
Unluckily, this actually doesn't work all the times and has a few limitations we need to address
In particular, it doesn't address seamless dialogs use case (which always have 'aria-modal' equal to false) and dialogs without backdrop, which are equally not considered modals, and thus have 'aria-modal' equal to false
We should find a more reliable way to check for persistent dialogs, possibly even add a custom dedicated class into Quasar core for QDialog
Just a convenience method to avoid the more verbose form of withinDialog
Before
cy.withinDialog({
persistent: true,
fn: () => {
// ...
}
})
After
cy.withinPersistentDialog(() => {
// ...
})
We're considering adding some new helper commands related to QDialog
closeDialogViaEscKeyLimitation: this only works in
withinDialogcontext, as when using it outside it.root()will yeld "html" tag and Cypress won't be able to find anything with.closest('body')since it only searches upwardsWe should find a way to make it work both inside and outside a within context
I tried with
cy.window()andcy.document()already, which I recalled worked fine in the past, but it seems like they changed that behaviorMaybe by using the
Cypress.$('body')shortcut that we already use in portal-related commands?Even if it's an internal and undocumented feature AFAIK
closeDialogViaBackdropassertPersistentDialogExistsThis should be called automatically after the callback function of
withinDialogcompletes, ifpersistentis set totrueUnluckily, this actually doesn't work all the times and has a few limitations we need to address
In particular, it doesn't address seamless dialogs use case (which always have 'aria-modal' equal to
false) and dialogs without backdrop, which are equally not considered modals, and thus have 'aria-modal' equal tofalseWe should find a more reliable way to check for persistent dialogs, possibly even add a custom dedicated class into Quasar core for QDialog
withinPersistentDialogJust a convenience method to avoid the more verbose form of
withinDialogBefore
After