Skip to content

Commit

Permalink
workflow: open new tabs on top
Browse files Browse the repository at this point in the history
* Closes cylc#1090
* When a new tab (i.e. Cylc view) is opened it should be acitvated
  (i.e. put on top).
  • Loading branch information
oliver-sanders committed Dec 21, 2022
1 parent 38b01c8 commit bef212c
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 4 deletions.
8 changes: 6 additions & 2 deletions src/components/cylc/workflow/Lumino.vue
Original file line number Diff line number Diff line change
Expand Up @@ -126,16 +126,20 @@ export default {
* Create a widget.
*
*/
addWidget (id, name) {
addWidget (id, name, onTop = true) {
this.widgets.push(id)
const luminoWidget = new LuminoWidget(id, name, /* closable */ true)
this.dock.addWidget(luminoWidget)
// this.dock.addWidget(luminoWidget)
this.dock.addWidget(luminoWidget, { mode: 'tab-after' })
// give time for Lumino's widget DOM element to be created
this.$nextTick(() => {
document.getElementById(id)
.addEventListener('lumino:activated', this.onWidgetActivated)
document.getElementById(id)
.addEventListener('lumino:deleted', this.onWidgetDeleted)
if (onTop) {
luminoWidget.parent.selectWidget(luminoWidget)
}
})
},

Expand Down
22 changes: 20 additions & 2 deletions tests/e2e/specs/workflow.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,10 +55,28 @@ describe('Workflow view and component/widget', () => {

it('Should be able to add two widgets of different types', () => {
cy.visit('/#/workflows/one')
cy.get('.lm-TabBar-tabLabel').should('have.length', 1)

// there should be one widget open by default (tree)
cy.get('.lm-TabBar-tabLabel')
// there should be a tab representing the widget
.should('have.length', 1)
// the tab should contain the name of the widget
.contains('tree')
// the tab should be active (that is to say on top)
.parent()
.should('have.class', 'lm-mod-current')

cy.get('a.add-view').click()
cy.get('#toolbar-add-Table-view').click()
cy.get('.lm-TabBar-tabLabel').should('have.length', 2)
cy.get('.lm-TabBar-tabLabel')
// there should be two tabs (tree + table)
.should('have.length', 2)
// the new tab should be last
.last()
.contains('table')
// the new tab should be active (that is to say on top)
.parent()
.should('have.class', 'lm-mod-current')
})

it('Should remove widgets added successfully', () => {
Expand Down

0 comments on commit bef212c

Please sign in to comment.