Skip to content

Commit

Permalink
Merge pull request #1560 from ProcessMaker/bugfix/FOUR-14293
Browse files Browse the repository at this point in the history
FOUR-14293 Add scroll to page drowp down
  • Loading branch information
ryancooley authored Mar 7, 2024
2 parents 95a00ff + 04afb64 commit 400e85d
Show file tree
Hide file tree
Showing 7 changed files with 142 additions and 17 deletions.
2 changes: 2 additions & 0 deletions sonar-project.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,5 @@ sonar.javascript.lcov.reportPaths=./coverage/lcov.info
sonar.exclusions=node_modules/**, dist/**, public/**, home/**, storybook-static/**
sonar.sources=src
sonar.tests=tests
sonar.cpd.exclusions=src/stories/**
sonar.coverage.exclusions=src/stories/**
3 changes: 3 additions & 0 deletions src/assets/css/custom.css
Original file line number Diff line number Diff line change
Expand Up @@ -8,4 +8,7 @@
}
.page-dropdown-menu {
min-width: 333px;
max-height: 26rem;
overflow-y: auto;
scrollbar-width: thin;
}
7 changes: 4 additions & 3 deletions src/components/TabsBar.vue
Original file line number Diff line number Diff line change
Expand Up @@ -197,9 +197,10 @@ export default {
}, visualThreshold);
});
},
closeTab(pageId) {
this.localOpenedPages.splice(this.localOpenedPages.indexOf(pageId), 1);
this.$emit("tab-closed", this.pages[pageId], this.localOpenedPages);
closeTab(tabIndex) {
const pageIndex = this.localOpenedPages[tabIndex];
this.localOpenedPages.splice(tabIndex, 1);
this.$emit("tab-closed", this.pages[pageIndex], this.localOpenedPages);
},
updateTabsReferences(pageDelete) {
this.localOpenedPages = this.localOpenedPages.map((page) =>
Expand Down
39 changes: 27 additions & 12 deletions src/components/sortable/sortableList/SortableList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,16 @@
<div class="rounded sortable-item-name">
<b-form-input
v-if="editRowIndex === index"
v-model="item.name"
v-model="newName"
type="text"
autofocus
required
:state="validateState(item.name, item)"
:error="validateError(item.name, item)"
@blur.stop="onBlur(item.name, item)"
@keydown.enter.stop="onBlur(item.name, item)"
@focus="onFocus(item.name, item)"
:state="validateState(newName, item)"
:error="validateError(newName, item)"
@blur.stop="onBlur(newName, item)"
@keydown.enter.stop="onBlur(newName, item)"
@keydown.esc.stop="onCancel(item)"
@focus="onFocus(item)"
/>
<span v-else>{{ item.name }}</span>
</div>
Expand Down Expand Up @@ -63,7 +64,7 @@ export default {
},
data() {
return {
originalName: '',
newName: '',
draggedItem: 0,
draggedOverItem: 0,
editRowIndex: null,
Expand All @@ -79,14 +80,14 @@ export default {
},
methods: {
validateState(name, item) {
const isEmpty = !name;
const isEmpty = !name?.trim();
const isDuplicated = this.items
.filter((i) => i !== item)
.find((i) => i.name === name);
return isEmpty || isDuplicated ? false : null;
},
validateError(name, item) {
const isEmpty = !name;
const isEmpty = !name?.trim();
if (!isEmpty) {
return this.$t("The Page Name field is required.");
}
Expand All @@ -98,19 +99,25 @@ export default {
}
return '';
},
onFocus(name, item) {
this.originalName = name;
onFocus(item) {
this.newName = item.name;
},
async onBlur(name, item) {
if (this.validateState(name, item) === false) {
this.newName = item.name;
} else {
// eslint-disable-next-line no-param-reassign
item.name = this.originalName;
item.name = name;
}
await this.$nextTick();
setTimeout(() => {
this.editRowIndex = null;
}, 250);
},
async onCancel(item) {
this.newName = item.name;
this.editRowIndex = null;
},
onClick(item, index) {
this.editRowIndex = index;
this.$emit("item-edit", item);
Expand Down Expand Up @@ -162,6 +169,14 @@ export default {
itemsSortedClone[draggedItemIndex].order = tempOrder;
}
// Update order of the items
const clone = [...itemsSortedClone];
clone.sort((a, b) => a.order - b.order);
clone.forEach((item, index) => {
// eslint-disable-next-line no-param-reassign
item.order = index + 1;
});
}
this.$emit('ordered', itemsSortedClone);
Expand Down
16 changes: 15 additions & 1 deletion src/components/vue-form-builder.vue
Original file line number Diff line number Diff line change
Expand Up @@ -881,6 +881,7 @@ export default {
config.forEach((page) => this.replaceFormText(page.items));
config.forEach((page) => this.migrateFormSubmit(page.items));
config.forEach((page) => this.updateFieldNameValidation(page.items));
this.updatePageOrder(config);
config.forEach((page) =>
this.removeDataVariableFromNestedScreens(page.items)
);
Expand All @@ -889,6 +890,18 @@ export default {
page.order = page.order || index + 1;
});
},
updatePageOrder(pages) {
const clone = [...pages];
clone.sort((a, b) => {
const aOrder = a.order || pages.indexOf(a) + 1;
const bOrder = b.order || pages.indexOf(b) + 1;
return aOrder - bOrder;
});
clone.forEach((item, index) => {
// eslint-disable-next-line no-param-reassign
item.order = index + 1;
});
},
updateFieldNameValidation(items) {
items.forEach((item) => {
if (item.inspector) {
Expand Down Expand Up @@ -1148,9 +1161,9 @@ export default {
this.updateState();
},
addPage(e) {
this.showAddPageValidations = true;
const error = this.checkPageName(this.addPageName, true);
if (error) {
this.showAddPageValidations = true;
e.preventDefault();
return;
}
Expand Down Expand Up @@ -1227,6 +1240,7 @@ export default {
globalObject.ProcessMaker.alert(error.message, "danger");
return;
}
this.updatePageOrder(this.config);
this.$store.dispatch("undoRedoModule/pushState", {
config: JSON.stringify(this.config),
currentPage: this.currentPage,
Expand Down
35 changes: 34 additions & 1 deletion src/stories/DropdownAndPages.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,6 @@ export const OpenPageUsingDropdown = {
"[data-test=page-dropdown] button"
);
let selectorAddPage = canvasElement.querySelector("[data-test=page-Page3]");
console.log(selectorAddPage);
await selector.click(selector);
await selectorAddPage.click(selectorAddPage);
// Open Page 3 (index=2)
Expand Down Expand Up @@ -111,3 +110,37 @@ export const OpenPageUsingDropdown = {
});
}
};

// Open a page using the PageDropdown(index)
export const ScrollWithMoreThanTenPages = {
args: {
pages: [
{ name: "Page1" },
{ name: "Page2" },
{ name: "Page3" },
{ name: "Page4" },
{ name: "Page5" },
{ name: "Page6" },
{ name: "Page7" },
{ name: "Page8" },
{ name: "Page9" },
{ name: "Page10" },
{ name: "Page11" },
{ name: "Page12" }
],
initialOpenedPages: [0]
},
play: async ({ canvasElement }) => {
const selector = canvasElement.querySelector(
"[data-test=page-dropdown] button"
);
await selector.click(selector);
// Test .page-dropdown-menu has scroll (scrollHeight > clientHeight)
await waitFor(() => {
const dropdownMenu = canvasElement.querySelector(".page-dropdown-menu");
expect(dropdownMenu.scrollHeight).toBeGreaterThan(
dropdownMenu.clientHeight
);
});
}
};
57 changes: 57 additions & 0 deletions src/stories/PageTabs.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -336,3 +336,60 @@ export const WithoutAnyPageOpened = {
);
}
};

// User can close tabs
export const UserCanCloseTabs = {
args: {
pages: [
{ name: "Page 1" },
{ name: "Page 2" },
{ name: "Page 3" },
{ name: "Page 4" },
{ name: "Page 5" }
],
initialOpenedPages: [0, 1, 2, 3, 4]
},
play: async ({ canvasElement, step }) => {
const canvas = within(canvasElement);

// Close Tab #1 = Page 1 (tab index=0)
await step("Close Page 1 (tab index=0)", async () => {
canvas.getByTestId("close-tab-0").click();
await waitFor(
() => {
expect(canvas.getByTestId("tab-content")).toContainHTML(
"Here comes content of Page 2 (#1)"
);
},
{ timeout: 1000 }
);
});

// Close Tab #1 = Page 2 (tab index=0)
await step("Close Page 2 (tab index=0)", async () => {
canvas.getByTestId("close-tab-0").click();
await waitFor(
() => {
expect(canvas.getByTestId("tab-content")).toContainHTML(
"Here comes content of Page 3 (#2)"
);
},
{ timeout: 1000 }
);
});

// Close Tab #2 = Page 4 (tab index=1)
await step("Close Page 4 (tab index=1)", async () => {
canvas.getByTestId("close-tab-1").click();
await waitFor(
() => {
// keep focus in the tab #1
expect(canvas.getByTestId("tab-content")).toContainHTML(
"Here comes content of Page 3 (#2)"
);
},
{ timeout: 1000 }
);
});
}
};

0 comments on commit 400e85d

Please sign in to comment.