import React, {useState} from "react"
import { render, screen, waitFor } from "../utilities/test-utils"
import { AdvancedTable, Pill } from "playbook-ui"
const MOCK_DATA = [
{
year: "2021",
quarter: null,
month: null,
day: null,
newEnrollments: "20",
scheduledMeetings: "10",
children: [
{
year: "2021",
quarter: "Q1",
month: null,
day: null,
newEnrollments: "2",
scheduledMeetings: "35",
},
],
},
{
year: "2022",
quarter: null,
month: null,
day: null,
newEnrollments: "20",
scheduledMeetings: "10",
children: [
{
year: "2022",
quarter: "Q1",
month: null,
day: null,
newEnrollments: "2",
scheduledMeetings: "35",
},
],
},
]
const MOCK_DATA_LOADING = [
{
year: "2021",
quarter: null,
month: null,
day: null,
newEnrollments: "20",
scheduledMeetings: "10",
children: [],
},
{
year: "2022",
quarter: null,
month: null,
day: null,
newEnrollments: "20",
scheduledMeetings: "10",
children: [
{
year: "2022",
quarter: "Q1",
month: null,
day: null,
newEnrollments: "2",
scheduledMeetings: "35",
},
],
},
]
const columnDefinitions = [
{
accessor: "year",
label: "Year",
cellAccessors: ["quarter", "month", "day"],
},
{
accessor: "newEnrollments",
label: "New Enrollments",
},
{
accessor: "scheduledMeetings",
label: "Scheduled Meetings",
},
]
const columnDefinitionsCustomRenderer = [
{
accessor: "year",
label: "Year",
cellAccessors: ["quarter", "month", "day"],
},
{
accessor: "newEnrollments",
label: "New Enrollments",
customRenderer: (row, value) => (
),
},
{
accessor: "scheduledMeetings",
label: "Scheduled Meetings",
},
]
const subRowHeaders = ["Quarter"]
const testId = "advanced_table"
const AdvancedTableExpandControl = () => {
const [expanded, setExpanded] = useState({'0': true})
const expandedControl = {
value: expanded,
onChange: setExpanded,
}
return (
)
}
const AdvancedTableSortControl = () => {
const [isSortDesc, setIsSortDesc] = useState({desc: false})
const sortControl = {
value: isSortDesc,
onChange: setIsSortDesc,
}
return (
)
}
const tableOptions = {
initialState: {
sorting: [
{
id: "year",
desc: true,
},
],
},
}
const tableProps = {
container: false,
sticky: true
}
test("Generates default kit and classname", () => {
render(
)
const kit = screen.getByTestId(testId)
expect(kit).toBeInTheDocument()
expect(kit).toHaveClass('pb_advanced_table')
})
test("Generates aria label", () => {
render(
)
const kit = screen.getByTestId(testId)
expect(kit).toHaveAttribute('aria-label', testId)
})
test("Row toggle button exists and toggles subrows open and closed", () => {
render(
)
const kit = screen.getByTestId(testId)
const rowButton = kit.querySelector(".gray-icon.expand-toggle-icon")
expect(rowButton).toBeInTheDocument()
const subRow1 = kit.querySelector(".bg-white.depth-sub-row-1")
expect(subRow1).not.toBeInTheDocument()
rowButton.click()
const subRow = kit.querySelector(".bg-white.depth-sub-row-1")
expect(subRow).toBeInTheDocument()
})
test("toggleExpansionAll button exists and toggles subrows open and closed", async () => {
render(
)
const kit = screen.getByTestId(testId);
const toggleButton = kit.querySelector(".gray-icon.toggle-all-icon");
expect(toggleButton).toBeInTheDocument();
const subRow1 = kit.querySelector(".bg-white.depth-sub-row-1");
expect(subRow1).not.toBeInTheDocument();
toggleButton.click();
await waitFor(() => {
const subRow = kit.querySelector(".bg-white.depth-sub-row-1");
expect(subRow).toBeInTheDocument();
})
})
test("loading state + initialLoadingRowCount prop", () => {
render(
)
const kit = screen.getByTestId(testId)
const table = kit.querySelector('table')
expect(table).toHaveClass('pb_table table-sm table-responsive-none table-card data_table ns_tabular content-loading')
const tableBody = kit.querySelector('tbody')
const tableRows = tableBody.getElementsByTagName('tr')
expect(tableRows).toHaveLength(13)
})
test("subRowHeaders are rendered", () => {
render(
)
const kit = screen.getByTestId(testId)
const rowButton = kit.querySelector(".gray-icon.expand-toggle-icon")
rowButton.click()
const subRowHeader = kit.querySelector(".custom-row.bg-silver")
expect(subRowHeader).toBeInTheDocument()
})
test("expandControl prop works as expected", () => {
render ()
const kit = screen.getByTestId(testId)
const subRow = kit.querySelector(".bg-white.depth-sub-row-1")
expect(subRow).toBeInTheDocument()
})
test("tableOptions prop functions as expected", () => {
render(
)
const kit = screen.getByTestId(testId)
const row1 = kit.getElementsByTagName('tr')[1]
expect(row1.id).toBe("1-1-0-row")
})
test("tableProps prop functions as expected", () => {
render(
)
const kit = screen.getByTestId(testId)
const table = kit.querySelector('table')
expect(table).toHaveClass("pb_table table-sm table-responsive-none data_table sticky-header ns_tabular")
})
test("enableExpansionIcon changes icon", () => {
render(
)
const kit = screen.getByTestId(testId)
const tableHead = kit.querySelector('table')
const toggleIcon= tableHead.querySelector(".pb_icon_kit")
expect(toggleIcon).toHaveClass("fa-chevron-up")
})
test("sortIcon changes icon", () => {
render(
)
const kit = screen.getByTestId(testId)
const sortIcon = kit.querySelector('.sort-button-icon')
const icon= sortIcon.querySelector(".pb_icon_kit")
expect(icon).toHaveClass("fa-chevron-down")
})
test("Sort icon renders with enableSorting + sortControl works as expected", () => {
render ()
const kit = screen.getByTestId(testId)
const sortIcon = kit.querySelector(".sort-button-icon")
expect(sortIcon).toBeInTheDocument()
const row1 = kit.getElementsByTagName('tr')[1]
expect(row1.id).toBe("1-1-0-row")
})
test("sort button exists and sorts column data", () => {
render(
)
const kit = screen.getByTestId(testId)
const sortButton= kit.querySelector(".pb_flex_kit_orientation_row_justify_content_between_align_items_top_spacing_none.pl_xxs.cursor_pointer.header-sort-button.pb_th_link")
expect(sortButton).toBeInTheDocument()
const row1 = kit.getElementsByTagName('tr')[1]
expect(row1.id).toBe("0-0-0-row")
sortButton.click()
const row2 = kit.getElementsByTagName('tr')[2]
expect(row2.id).toBe("0-0-0-row")
})
test("Generates Table.Header default + custom classname", () => {
render(
)
const kit = screen.getByTestId(testId)
const tableHeader = kit.querySelector('thead')
expect(tableHeader).toHaveClass('pb_advanced_table_header custom-header')
})
test("Generates Table.Body default + custom classname", () => {
render(
)
const kit = screen.getByTestId(testId)
const tableHeader = kit.querySelector('tbody')
expect(tableHeader).toHaveClass('pb_advanced_table_body custom-body-classname')
})
test("inlineRowLoading prop renders inline loading if true", () => {
render(
)
const kit = screen.getByTestId(testId)
const rowButton = kit.querySelector(".gray-icon.expand-toggle-icon")
expect(rowButton).toBeInTheDocument()
rowButton.click()
const inlineLoading = kit.querySelector(".fa-spinner")
expect(inlineLoading).toBeInTheDocument()
})
test("responsive prop functions as expected", () => {
render(
)
const kit = screen.getByTestId(testId)
expect(kit).toHaveClass("pb_advanced_table advanced-table-responsive-scroll")
})
test("responsive none prop functions as expected", () => {
render(
)
const kit = screen.getByTestId(testId)
expect(kit).toHaveClass("pb_advanced_table advanced-table-responsive-none")
})
test("customRenderer prop functions as expected", () => {
render(
)
const kit = screen.getByTestId(testId)
const pill = kit.querySelector(".pb_pill_kit_success_lowercase")
expect(pill).toBeInTheDocument()
})