2020-11-05 10:22:05 +00:00
|
|
|
import React from 'react'
|
|
|
|
import PropTypes from 'prop-types'
|
|
|
|
import { expect } from 'chai'
|
|
|
|
import { render } from '@testing-library/react'
|
|
|
|
|
|
|
|
import useExpandCollapse from '../../../../frontend/js/shared/hooks/use-expand-collapse'
|
|
|
|
|
|
|
|
const sampleContent = (
|
|
|
|
<div>
|
|
|
|
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
|
|
|
|
<p>Maecenas maximus ultrices sollicitudin.</p>
|
|
|
|
<p>Praesent mollis arcu eget molestie viverra.</p>
|
|
|
|
<p>Pellentesque eget molestie nisl, non hendrerit lectus.</p>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
|
2020-12-02 10:03:03 +00:00
|
|
|
const originalScrollHeight = Object.getOwnPropertyDescriptor(
|
|
|
|
HTMLElement.prototype,
|
|
|
|
'offsetHeight'
|
|
|
|
)
|
|
|
|
const originalScrollWidth = Object.getOwnPropertyDescriptor(
|
|
|
|
HTMLElement.prototype,
|
|
|
|
'offsetWidth'
|
|
|
|
)
|
|
|
|
|
2020-11-05 10:22:05 +00:00
|
|
|
function ExpandCollapseTestUI({ expandCollapseArgs }) {
|
|
|
|
const { expandableProps } = useExpandCollapse(expandCollapseArgs)
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<div {...expandableProps}>{sampleContent}</div>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
ExpandCollapseTestUI.propTypes = {
|
2021-04-27 07:52:58 +00:00
|
|
|
expandCollapseArgs: PropTypes.object,
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('useExpandCollapse', function () {
|
2020-12-02 10:03:03 +00:00
|
|
|
// JSDom doesn't compute layout/sizing, so we need to simulate sizing for the elements
|
|
|
|
// Here we are simulating that the content is bigger than the `collapsedSize`, so
|
|
|
|
// the expand-collapse widget is used
|
2021-04-14 13:17:21 +00:00
|
|
|
beforeEach(function () {
|
2020-12-02 10:03:03 +00:00
|
|
|
Object.defineProperty(HTMLElement.prototype, 'scrollHeight', {
|
|
|
|
configurable: true,
|
2021-04-27 07:52:58 +00:00
|
|
|
value: 500,
|
2020-12-02 10:03:03 +00:00
|
|
|
})
|
|
|
|
Object.defineProperty(HTMLElement.prototype, 'scrollWidth', {
|
|
|
|
configurable: true,
|
2021-04-27 07:52:58 +00:00
|
|
|
value: 500,
|
2020-12-02 10:03:03 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
afterEach(function () {
|
2020-12-02 10:03:03 +00:00
|
|
|
Object.defineProperty(
|
|
|
|
HTMLElement.prototype,
|
|
|
|
'scrollHeight',
|
|
|
|
originalScrollHeight
|
|
|
|
)
|
|
|
|
Object.defineProperty(
|
|
|
|
HTMLElement.prototype,
|
|
|
|
'scrollWidth',
|
|
|
|
originalScrollWidth
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('custom CSS classes', function () {
|
|
|
|
it('supports a custom CSS class', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
|
|
|
classes: {
|
2021-04-27 07:52:58 +00:00
|
|
|
container: 'my-custom-class',
|
|
|
|
},
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const elWithCustomCSSClass = container.querySelector('div')
|
|
|
|
expect(elWithCustomCSSClass).to.exist
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
it('supports an extra custom CSS class for the collapsed state', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
|
|
|
classes: {
|
2021-04-27 07:52:58 +00:00
|
|
|
containerCollapsed: 'my-custom-collapsed-class',
|
|
|
|
},
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const elWithCustomCollapsedCSSClass = container.querySelector(
|
|
|
|
'.my-custom-collapsed-class'
|
|
|
|
)
|
|
|
|
expect(elWithCustomCollapsedCSSClass).to.exist
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
it('ignores the collapsed CSS class when expanded', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
|
|
|
initiallyExpanded: true,
|
|
|
|
classes: {
|
2021-04-27 07:52:58 +00:00
|
|
|
containerCollapsed: 'my-custom-collapsed-class',
|
|
|
|
},
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const elWithCustomCollapsedCSSClass = container.querySelector(
|
|
|
|
'.my-custom-collapsed-class'
|
|
|
|
)
|
|
|
|
expect(elWithCustomCollapsedCSSClass).to.not.exist
|
|
|
|
})
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('height and width support via dimension argument', function () {
|
|
|
|
it('defaults to height', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const { container } = render(<ExpandCollapseTestUI />)
|
|
|
|
const expandCollapseEl = container.firstChild
|
|
|
|
expect(expandCollapseEl.style.height).to.not.be.empty
|
|
|
|
expect(expandCollapseEl.style.width).to.be.empty
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
it('supports width', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
2021-04-27 07:52:58 +00:00
|
|
|
dimension: 'width',
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const expandCollapseEl = container.firstChild
|
|
|
|
expect(expandCollapseEl.style.height).to.be.empty
|
|
|
|
expect(expandCollapseEl.style.width).to.not.be.empty
|
|
|
|
})
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('collapsed size support via collapsedSize argument', function () {
|
|
|
|
it('defaults to 0px', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const { container } = render(<ExpandCollapseTestUI />)
|
|
|
|
const expandCollapseEl = container.firstChild
|
|
|
|
expect(expandCollapseEl.style.height).to.equal('0px')
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
it('supports a custom collapsed size', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
2021-04-27 07:52:58 +00:00
|
|
|
collapsedSize: 200,
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const expandCollapseEl = container.firstChild
|
|
|
|
expect(expandCollapseEl.style.height).to.equal('200px')
|
|
|
|
})
|
2021-04-14 13:17:21 +00:00
|
|
|
it('supports a custom collapsed size for width', function () {
|
2020-11-05 10:22:05 +00:00
|
|
|
const testArgs = {
|
|
|
|
collapsedSize: 200,
|
2021-04-27 07:52:58 +00:00
|
|
|
dimension: 'width',
|
2020-11-05 10:22:05 +00:00
|
|
|
}
|
|
|
|
const { container } = render(
|
|
|
|
<ExpandCollapseTestUI expandCollapseArgs={testArgs} />
|
|
|
|
)
|
|
|
|
const expandCollapseEl = container.firstChild
|
|
|
|
expect(expandCollapseEl.style.height).to.be.empty
|
|
|
|
expect(expandCollapseEl.style.width).to.equal('200px')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|