From 549b07f0fc263584745b6bbb90acd3974ba8329c Mon Sep 17 00:00:00 2001 From: Shubham Sharma <68867418+skv93-coder@users.noreply.github.com> Date: Wed, 27 Dec 2023 22:55:52 +0530 Subject: [PATCH] Added sort by for groups by creation date and member groups. (#659) * Added sort by creation date and members. * Reduced padding * Remove dead code * Made small modification * Changed the dropdown opening lines in test * Changed the variables name * Changed the variabled name * Changed variabled name * Changed variable names * Added sort by last used on --------- Co-authored-by: Shubham Sharma --- __tests__/groups/group.test.js | 87 +++++++++++++++++++++- groups/constants.js | 12 +++- groups/index.html | 8 +++ groups/script.js | 127 +++++++++++++++++++++++++-------- groups/style.css | 61 +++++++++++++++- mock-data/groups/index.js | 8 +++ 6 files changed, 267 insertions(+), 36 deletions(-) diff --git a/__tests__/groups/group.test.js b/__tests__/groups/group.test.js index fb43d37d..71f43676 100644 --- a/__tests__/groups/group.test.js +++ b/__tests__/groups/group.test.js @@ -3,6 +3,7 @@ const { allUsersData } = require('../../mock-data/users'); const { discordGroups, GroupRoleData } = require('../../mock-data/groups'); const BASE_URL = 'https://api.realdevsquad.com'; +const PAGE_URL = 'http://localhost:8000'; describe('Discord Groups Page', () => { let browser; @@ -135,7 +136,7 @@ describe('Discord Groups Page', () => { interceptedRequest.continue(); } }); - await page.goto('http://localhost:8000/groups'); + await page.goto(`${PAGE_URL}/groups`); await page.waitForNetworkIdle(); }); @@ -319,7 +320,7 @@ describe('Discord Groups Page', () => { }); test('should update input field and filter group list with search value in URL', async () => { - await page.goto('http://localhost:8000/groups/?dev=true&DSA'); + await page.goto(`${PAGE_URL}/groups/?dev=true&DSA`); manageGroup = await page.$('.manage-groups-tab'); await manageGroup.click(); const searchInput = await page.$('#search-groups'); @@ -341,7 +342,7 @@ describe('Discord Groups Page', () => { }); test('should select the group from URL and have active-group class', async () => { - await page.goto('http://localhost:8000/groups?DSA'); + await page.goto(`${PAGE_URL}/groups?DSA`); const activeGroup = await page.$('.active-group'); const groupName = await page.evaluate( (element) => element.innerText, @@ -349,4 +350,84 @@ describe('Discord Groups Page', () => { ); expect(groupName).toMatch('DSA'); }); + test('On click on "Popular within dev" will result group with most member at the top', async () => { + await page.goto(`${PAGE_URL}/groups?dev=true`); + await page.waitForNetworkIdle(); + + const groupsBeforeSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => + element.getAttribute('data-member-count'), + ); + }); + await page.$$eval('#dropdown_main', (el) => { + el[0].click(); + }); + + await page.$$eval('[data-list="1"]', (el) => { + el[0].click(); + }); + const groupsAfterSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => + element.getAttribute('data-member-count'), + ); + }); + const manualSortedGroup = groupsBeforeSort.sort((a, b) => b - a); + expect(groupsAfterSort).toEqual(manualSortedGroup); + }); + test('On click on "Recently created" will result in latest created group at the top', async () => { + await page.goto(`${PAGE_URL}/groups?dev=true`); + await page.waitForNetworkIdle(); + + const groupNameCreateDateLookup = {}; + discordGroups.groups.forEach((group) => { + const grpName = group.rolename.split('-').slice(1).join('-'); + groupNameCreateDateLookup[grpName] = group.date._seconds; + }); + const groupsBeforeSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => element.innerText); + }); + + await page.$$eval('#dropdown_main', (el) => { + el[0].click(); + }); + await page.$$eval('[data-list="2"]', (el) => { + el[0].click(); + }); + const groupAfterSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => element.innerText); + }); + const manualSortedGroup = groupsBeforeSort.sort( + (a, b) => groupNameCreateDateLookup[b] - groupNameCreateDateLookup[a], + ); + expect(groupAfterSort).toEqual(manualSortedGroup); + }); + test('On click on "Recently used" will result in recently used group at the top', async () => { + await page.goto(`${PAGE_URL}/groups?dev=true`); + await page.waitForNetworkIdle(); + + const groupNameCreateDateLookup = {}; + discordGroups.groups.forEach((group) => { + const grpName = group.rolename.split('-').slice(1).join('-'); + groupNameCreateDateLookup[grpName] = group.lastUsedOn + ? group.lastUsedOn._seconds + : 0; + }); + const groupsBeforeSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => element.innerText); + }); + + await page.$$eval('#dropdown_main', (el) => { + el[0].click(); + }); + await page.$$eval('[data-list="3"]', (el) => { + el[0].click(); + }); + const groupAfterSort = await page.$$eval('.group-name', (elements) => { + return elements.map((element) => element.innerText); + }); + const manualSortedGroup = groupsBeforeSort.sort( + (a, b) => groupNameCreateDateLookup[b] - groupNameCreateDateLookup[a], + ); + expect(groupAfterSort).toEqual(manualSortedGroup); + }); }); diff --git a/groups/constants.js b/groups/constants.js index 0ff87dfc..00e81726 100644 --- a/groups/constants.js +++ b/groups/constants.js @@ -1,5 +1,15 @@ const NO_SPACES_ALLOWED = 'Roles cannot have spaces'; const CANNOT_CONTAIN_GROUP = "Roles cannot contain 'group'."; const DEV_FEATURE_FLAG = 'dev'; +const SortByFields = [ + { id: '1', fieldName: 'memberCount' }, + { id: '2', fieldName: 'date._seconds' }, + { id: '3', fieldName: 'lastUsedOn._seconds' }, +]; -export { NO_SPACES_ALLOWED, CANNOT_CONTAIN_GROUP, DEV_FEATURE_FLAG }; +export { + SortByFields, + NO_SPACES_ALLOWED, + CANNOT_CONTAIN_GROUP, + DEV_FEATURE_FLAG, +}; diff --git a/groups/index.html b/groups/index.html index cd28f444..578cb88c 100644 --- a/groups/index.html +++ b/groups/index.html @@ -36,6 +36,14 @@