| /* eslint-env jquery */ |
| |
| import Alert from '../../src/alert.js' |
| import Button from '../../src/button.js' |
| import Carousel from '../../src/carousel.js' |
| import Collapse from '../../src/collapse.js' |
| import Dropdown from '../../src/dropdown.js' |
| import Modal from '../../src/modal.js' |
| import Offcanvas from '../../src/offcanvas.js' |
| import Popover from '../../src/popover.js' |
| import ScrollSpy from '../../src/scrollspy.js' |
| import Tab from '../../src/tab.js' |
| import Toast from '../../src/toast.js' |
| import Tooltip from '../../src/tooltip.js' |
| import { clearFixture, getFixture } from '../helpers/fixture.js' |
| |
| describe('jQuery', () => { |
| let fixtureEl |
| |
| beforeAll(() => { |
| fixtureEl = getFixture() |
| }) |
| |
| afterEach(() => { |
| clearFixture() |
| }) |
| |
| it('should add all plugins in jQuery', () => { |
| expect(Alert.jQueryInterface).toEqual(jQuery.fn.alert) |
| expect(Button.jQueryInterface).toEqual(jQuery.fn.button) |
| expect(Carousel.jQueryInterface).toEqual(jQuery.fn.carousel) |
| expect(Collapse.jQueryInterface).toEqual(jQuery.fn.collapse) |
| expect(Dropdown.jQueryInterface).toEqual(jQuery.fn.dropdown) |
| expect(Modal.jQueryInterface).toEqual(jQuery.fn.modal) |
| expect(Offcanvas.jQueryInterface).toEqual(jQuery.fn.offcanvas) |
| expect(Popover.jQueryInterface).toEqual(jQuery.fn.popover) |
| expect(ScrollSpy.jQueryInterface).toEqual(jQuery.fn.scrollspy) |
| expect(Tab.jQueryInterface).toEqual(jQuery.fn.tab) |
| expect(Toast.jQueryInterface).toEqual(jQuery.fn.toast) |
| expect(Tooltip.jQueryInterface).toEqual(jQuery.fn.tooltip) |
| }) |
| |
| it('should use jQuery event system', () => { |
| return new Promise(resolve => { |
| fixtureEl.innerHTML = [ |
| '<div class="alert">', |
| ' <button type="button" data-bs-dismiss="alert">x</button>', |
| '</div>' |
| ].join('') |
| |
| $(fixtureEl).find('.alert') |
| .one('closed.bs.alert', () => { |
| expect($(fixtureEl).find('.alert')).toHaveSize(0) |
| resolve() |
| }) |
| |
| $(fixtureEl).find('button').trigger('click') |
| }) |
| }) |
| }) |