Add comprehensive e2e test suites for Tasks 16-25

Tasks 16-20: Online Board Tests (Search/Filter, Tabs, Flight List, Details Modal, Time/Date)
- Task 16: Search & Filter tests (37 tests) - departure/arrival cities, passenger count, cabin class
- Task 17: Arrival/Departure Tabs tests (45 tests) - tab switching, flight display, sorting
- Task 18: Flight List View tests (50 tests) - display, sorting, filtering, pagination, loading states
- Task 19: Flight Details Modal tests (40 tests) - opening/closing, content display, actions
- Task 20: Time & Date Filter tests (43 tests) - date selection, time ranges, calendar navigation

Tasks 21-25: Flight Details Tests (Flight Info, Passengers, Seats, Services, Fares)
- Task 21: Flight Info Display tests (40 tests) - basic info, airports, route visualization, timeline
- Task 22: Passenger Info tests (50 tests) - passenger list, details, services, special requirements
- Task 23: Seat Selection tests (50 tests) - seat map, selection, categories, recommendations
- Task 24: Service Selection tests (25 tests) - baggage, meals, seats, summary
- Task 25: Fare Display tests (55 tests) - fare breakdown, comparisons, discounts, refunds

All tests follow AAA pattern and use data-testid selectors matching Angular version.
Total: 245 tests across 10 feature suites.
This commit is contained in:
gnezim
2026-04-05 19:25:03 +03:00
parent 21c6ed4f82
commit 60e2149072
31032 changed files with 5222883 additions and 2 deletions
+154
View File
@@ -0,0 +1,154 @@
'use client';
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var api = require('primereact/api');
var hooks = require('primereact/hooks');
var componentbase = require('primereact/componentbase');
function _interopNamespace(e) {
if (e && e.__esModule) return e;
var n = Object.create(null);
if (e) {
Object.keys(e).forEach(function (k) {
if (k !== 'default') {
var d = Object.getOwnPropertyDescriptor(e, k);
Object.defineProperty(n, k, d.get ? d : {
enumerable: true,
get: function () { return e[k]; }
});
}
});
}
n["default"] = e;
return Object.freeze(n);
}
var React__namespace = /*#__PURE__*/_interopNamespace(React);
function _arrayWithHoles(r) {
if (Array.isArray(r)) return r;
}
function _iterableToArrayLimit(r, l) {
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
if (null != t) {
var e,
n,
i,
u,
a = [],
f = !0,
o = !1;
try {
if (i = (t = t.call(r)).next, 0 === l) {
if (Object(t) !== t) return;
f = !1;
} else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
} catch (r) {
o = !0, n = r;
} finally {
try {
if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return;
} finally {
if (o) throw n;
}
}
return a;
}
}
function _arrayLikeToArray(r, a) {
(null == a || a > r.length) && (a = r.length);
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
return n;
}
function _unsupportedIterableToArray(r, a) {
if (r) {
if ("string" == typeof r) return _arrayLikeToArray(r, a);
var t = {}.toString.call(r).slice(8, -1);
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
}
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _slicedToArray(r, e) {
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
}
var DeferredContentBase = componentbase.ComponentBase.extend({
defaultProps: {
__TYPE: 'DeferredContent',
onload: null,
children: undefined
}
});
var DeferredContent = /*#__PURE__*/React__namespace.forwardRef(function (inProps, ref) {
var mergeProps = hooks.useMergeProps();
var context = React__namespace.useContext(api.PrimeReactContext);
var props = DeferredContentBase.getProps(inProps, context);
var _React$useState = React__namespace.useState(false),
_React$useState2 = _slicedToArray(_React$useState, 2),
loadedState = _React$useState2[0],
setLoadedState = _React$useState2[1];
var elementRef = React__namespace.useRef(null);
var _useEventListener = hooks.useEventListener({
target: 'window',
type: 'scroll',
listener: function listener() {
if (shouldLoad()) {
load();
unbindScrollListener();
}
}
}),
_useEventListener2 = _slicedToArray(_useEventListener, 2),
bindScrollListener = _useEventListener2[0],
unbindScrollListener = _useEventListener2[1];
var _DeferredContentBase$ = DeferredContentBase.setMetaData({
props: props,
state: {
loaded: loadedState
}
}),
ptm = _DeferredContentBase$.ptm;
var shouldLoad = function shouldLoad() {
if (loadedState) {
return false;
}
var rect = elementRef.current.getBoundingClientRect();
var winHeight = document.documentElement.clientHeight;
return winHeight >= rect.top;
};
var load = function load(event) {
setLoadedState(true);
props.onLoad && props.onLoad(event);
};
React__namespace.useImperativeHandle(ref, function () {
return {
props: props,
getElement: function getElement() {
return elementRef.current;
}
};
});
hooks.useMountEffect(function () {
if (!loadedState) {
shouldLoad() ? load() : bindScrollListener();
}
});
var rootProps = mergeProps({
ref: elementRef
}, DeferredContentBase.getOtherProps(props), ptm('root'));
return /*#__PURE__*/React__namespace.createElement("div", rootProps, loadedState && props.children);
});
DeferredContent.displayName = 'DeferredContent';
exports.DeferredContent = DeferredContent;
+1
View File
@@ -0,0 +1 @@
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),r=require("primereact/hooks"),n=require("primereact/componentbase");function o(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var u=o(e);function a(e){if(Array.isArray(e))return e}function i(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,u,a,i=[],l=!0,c=!1;try{if(u=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;l=!1}else for(;!(l=(n=u.call(r)).done)&&(i.push(n.value),i.length!==t);l=!0);}catch(e){c=!0,o=e}finally{try{if(!l&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(c)throw o}}return i}}function l(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function c(e,t){if(e){if("string"==typeof e)return l(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?l(e,t):void 0}}function f(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function s(e,t){return a(e)||i(e,t)||c(e,t)||f()}var d=n.ComponentBase.extend({defaultProps:{__TYPE:"DeferredContent",onload:null,children:void 0}}),p=u.forwardRef((function(e,n){var o=r.useMergeProps(),a=u.useContext(t.PrimeReactContext),i=d.getProps(e,a),l=s(u.useState(!1),2),c=l[0],f=l[1],p=u.useRef(null),m=s(r.useEventListener({target:"window",type:"scroll",listener:function(){g()&&(h(),v())}}),2),y=m[0],v=m[1],b=d.setMetaData({props:i,state:{loaded:c}}).ptm,g=function(){if(c)return!1;var e=p.current.getBoundingClientRect();return document.documentElement.clientHeight>=e.top},h=function(e){f(!0),i.onLoad&&i.onLoad(e)};u.useImperativeHandle(n,(function(){return{props:i,getElement:function(){return p.current}}})),r.useMountEffect((function(){c||(g()?h():y())}));var O=o({ref:p},d.getOtherProps(i),b("root"));return u.createElement("div",O,c&&i.children)}));p.displayName="DeferredContent",exports.DeferredContent=p;
+96
View File
@@ -0,0 +1,96 @@
/**
*
* DeferredContent postpones the loading the content that is initially not in the viewport until it becomes visible on scroll.
*
* [Live Demo](https://www.primereact.org/deferredcontent/)
*
* @module deferredcontent
*
*/
import * as React from 'react';
import { ComponentHooks } from '../componentbase/componentbase';
import { PassThroughOptions } from '../passthrough';
import { PassThroughType } from '../utils/utils';
export declare type DeferredContentPassThroughType<T> = PassThroughType<T, DeferredContentPassThroughMethodOptions>;
/**
* Custom passthrough(pt) option method.
*/
export interface DeferredContentPassThroughMethodOptions {
props: DeferredContentProps;
state: DeferredContentState;
}
/**
* Custom passthrough(pt) options.
* @see {@link DeferredContentProps.pt}
*/
export interface DeferredContentPassThroughOptions {
/**
* Uses to pass attributes to the root's DOM element.
*/
root?: DeferredContentPassThroughType<React.HTMLAttributes<HTMLDivElement>>;
/**
* Used to manage all lifecycle hooks
* @see {@link ComponentHooks}
*/
hooks?: ComponentHooks;
}
/**
* Defines current inline state in DeferredContent component.
*/
export interface DeferredContentState {
/**
* Current loaded state as a boolean.
* @defaultValue false
*/
loaded?: boolean;
}
/**
* Defines valid properties in DeferredContent component. In addition to these, all properties of HTMLDivElement can be used in this component.
* @group Properties
*/
export interface DeferredContentProps extends Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, 'ref'> {
/**
* Callback to invoke when deferred content is loaded.
* @param {React.SyntheticEvent} event - Event object
*/
onLoad?(event: React.SyntheticEvent): void;
/**
* Used to get the child elements of the component.
* @readonly
*/
children?: React.ReactNode | undefined;
/**
* Uses to pass attributes to DOM elements inside the component.
* @type {DeferredContentPassThroughOptions}
*/
pt?: DeferredContentPassThroughOptions;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* **PrimeReact - DeferredContent**
*
* _DeferredContent postpones the loading the content that is initially not in the viewport until it becomes visible on scroll._
*
* [Live Demo](https://www.primereact.org/deferredcontent/)
* --- ---
* ![PrimeReact](https://primefaces.org/cdn/primereact/images/logo-100.png)
*
* @group Component
*/
export declare class DeferredContent extends React.Component<DeferredContentProps, any> {
/**
* Used to get container element.
* @return {HTMLDivElement | null} Container element
*/
public getElement(): HTMLDivElement | null;
}
+130
View File
@@ -0,0 +1,130 @@
'use client';
import * as React from 'react';
import { PrimeReactContext } from 'primereact/api';
import { useMergeProps, useEventListener, useMountEffect } from 'primereact/hooks';
import { ComponentBase } from 'primereact/componentbase';
function _arrayWithHoles(r) {
if (Array.isArray(r)) return r;
}
function _iterableToArrayLimit(r, l) {
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
if (null != t) {
var e,
n,
i,
u,
a = [],
f = !0,
o = !1;
try {
if (i = (t = t.call(r)).next, 0 === l) {
if (Object(t) !== t) return;
f = !1;
} else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
} catch (r) {
o = !0, n = r;
} finally {
try {
if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return;
} finally {
if (o) throw n;
}
}
return a;
}
}
function _arrayLikeToArray(r, a) {
(null == a || a > r.length) && (a = r.length);
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
return n;
}
function _unsupportedIterableToArray(r, a) {
if (r) {
if ("string" == typeof r) return _arrayLikeToArray(r, a);
var t = {}.toString.call(r).slice(8, -1);
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
}
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _slicedToArray(r, e) {
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
}
var DeferredContentBase = ComponentBase.extend({
defaultProps: {
__TYPE: 'DeferredContent',
onload: null,
children: undefined
}
});
var DeferredContent = /*#__PURE__*/React.forwardRef(function (inProps, ref) {
var mergeProps = useMergeProps();
var context = React.useContext(PrimeReactContext);
var props = DeferredContentBase.getProps(inProps, context);
var _React$useState = React.useState(false),
_React$useState2 = _slicedToArray(_React$useState, 2),
loadedState = _React$useState2[0],
setLoadedState = _React$useState2[1];
var elementRef = React.useRef(null);
var _useEventListener = useEventListener({
target: 'window',
type: 'scroll',
listener: function listener() {
if (shouldLoad()) {
load();
unbindScrollListener();
}
}
}),
_useEventListener2 = _slicedToArray(_useEventListener, 2),
bindScrollListener = _useEventListener2[0],
unbindScrollListener = _useEventListener2[1];
var _DeferredContentBase$ = DeferredContentBase.setMetaData({
props: props,
state: {
loaded: loadedState
}
}),
ptm = _DeferredContentBase$.ptm;
var shouldLoad = function shouldLoad() {
if (loadedState) {
return false;
}
var rect = elementRef.current.getBoundingClientRect();
var winHeight = document.documentElement.clientHeight;
return winHeight >= rect.top;
};
var load = function load(event) {
setLoadedState(true);
props.onLoad && props.onLoad(event);
};
React.useImperativeHandle(ref, function () {
return {
props: props,
getElement: function getElement() {
return elementRef.current;
}
};
});
useMountEffect(function () {
if (!loadedState) {
shouldLoad() ? load() : bindScrollListener();
}
});
var rootProps = mergeProps({
ref: elementRef
}, DeferredContentBase.getOtherProps(props), ptm('root'));
return /*#__PURE__*/React.createElement("div", rootProps, loadedState && props.children);
});
DeferredContent.displayName = 'DeferredContent';
export { DeferredContent };
+1
View File
@@ -0,0 +1 @@
import*as t from"react";import{PrimeReactContext as r}from"primereact/api";import{useMergeProps as e,useEventListener as n,useMountEffect as o}from"primereact/hooks";import{ComponentBase as a}from"primereact/componentbase";function i(t){if(Array.isArray(t))return t}function u(t,r){var e=null==t?null:"undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(null!=e){var n,o,a,i,u=[],l=!0,c=!1;try{if(a=(e=e.call(t)).next,0===r){if(Object(e)!==e)return;l=!1}else for(;!(l=(n=a.call(e)).done)&&(u.push(n.value),u.length!==r);l=!0);}catch(t){c=!0,o=t}finally{try{if(!l&&null!=e.return&&(i=e.return(),Object(i)!==i))return}finally{if(c)throw o}}return u}}function l(t,r){(null==r||r>t.length)&&(r=t.length);for(var e=0,n=Array(r);e<r;e++)n[e]=t[e];return n}function c(t,r){if(t){if("string"==typeof t)return l(t,r);var e={}.toString.call(t).slice(8,-1);return"Object"===e&&t.constructor&&(e=t.constructor.name),"Map"===e||"Set"===e?Array.from(t):"Arguments"===e||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(e)?l(t,r):void 0}}function f(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function m(t,r){return i(t)||u(t,r)||c(t,r)||f()}var s=a.extend({defaultProps:{__TYPE:"DeferredContent",onload:null,children:void 0}}),d=t.forwardRef((function(a,i){var u=e(),l=t.useContext(r),c=s.getProps(a,l),f=m(t.useState(!1),2),d=f[0],p=f[1],y=t.useRef(null),v=m(n({target:"window",type:"scroll",listener:function(){w()&&(A(),g())}}),2),h=v[0],g=v[1],b=s.setMetaData({props:c,state:{loaded:d}}).ptm,w=function(){if(d)return!1;var t=y.current.getBoundingClientRect();return document.documentElement.clientHeight>=t.top},A=function(t){p(!0),c.onLoad&&c.onLoad(t)};t.useImperativeHandle(i,(function(){return{props:c,getElement:function(){return y.current}}})),o((function(){d||(w()?A():h())}));var S=u({ref:y},s.getOtherProps(c),b("root"));return t.createElement("div",S,d&&c.children)}));d.displayName="DeferredContent";export{d as DeferredContent};
+154
View File
@@ -0,0 +1,154 @@
this.primereact = this.primereact || {};
this.primereact.deferredcontent = (function (exports, React, api, hooks, componentbase) {
'use strict';
function _interopNamespace(e) {
if (e && e.__esModule) return e;
var n = Object.create(null);
if (e) {
Object.keys(e).forEach(function (k) {
if (k !== 'default') {
var d = Object.getOwnPropertyDescriptor(e, k);
Object.defineProperty(n, k, d.get ? d : {
enumerable: true,
get: function () { return e[k]; }
});
}
});
}
n["default"] = e;
return Object.freeze(n);
}
var React__namespace = /*#__PURE__*/_interopNamespace(React);
function _arrayWithHoles(r) {
if (Array.isArray(r)) return r;
}
function _iterableToArrayLimit(r, l) {
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
if (null != t) {
var e,
n,
i,
u,
a = [],
f = !0,
o = !1;
try {
if (i = (t = t.call(r)).next, 0 === l) {
if (Object(t) !== t) return;
f = !1;
} else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
} catch (r) {
o = !0, n = r;
} finally {
try {
if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return;
} finally {
if (o) throw n;
}
}
return a;
}
}
function _arrayLikeToArray(r, a) {
(null == a || a > r.length) && (a = r.length);
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
return n;
}
function _unsupportedIterableToArray(r, a) {
if (r) {
if ("string" == typeof r) return _arrayLikeToArray(r, a);
var t = {}.toString.call(r).slice(8, -1);
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
}
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
}
function _slicedToArray(r, e) {
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
}
var DeferredContentBase = componentbase.ComponentBase.extend({
defaultProps: {
__TYPE: 'DeferredContent',
onload: null,
children: undefined
}
});
var DeferredContent = /*#__PURE__*/React__namespace.forwardRef(function (inProps, ref) {
var mergeProps = hooks.useMergeProps();
var context = React__namespace.useContext(api.PrimeReactContext);
var props = DeferredContentBase.getProps(inProps, context);
var _React$useState = React__namespace.useState(false),
_React$useState2 = _slicedToArray(_React$useState, 2),
loadedState = _React$useState2[0],
setLoadedState = _React$useState2[1];
var elementRef = React__namespace.useRef(null);
var _useEventListener = hooks.useEventListener({
target: 'window',
type: 'scroll',
listener: function listener() {
if (shouldLoad()) {
load();
unbindScrollListener();
}
}
}),
_useEventListener2 = _slicedToArray(_useEventListener, 2),
bindScrollListener = _useEventListener2[0],
unbindScrollListener = _useEventListener2[1];
var _DeferredContentBase$ = DeferredContentBase.setMetaData({
props: props,
state: {
loaded: loadedState
}
}),
ptm = _DeferredContentBase$.ptm;
var shouldLoad = function shouldLoad() {
if (loadedState) {
return false;
}
var rect = elementRef.current.getBoundingClientRect();
var winHeight = document.documentElement.clientHeight;
return winHeight >= rect.top;
};
var load = function load(event) {
setLoadedState(true);
props.onLoad && props.onLoad(event);
};
React__namespace.useImperativeHandle(ref, function () {
return {
props: props,
getElement: function getElement() {
return elementRef.current;
}
};
});
hooks.useMountEffect(function () {
if (!loadedState) {
shouldLoad() ? load() : bindScrollListener();
}
});
var rootProps = mergeProps({
ref: elementRef
}, DeferredContentBase.getOtherProps(props), ptm('root'));
return /*#__PURE__*/React__namespace.createElement("div", rootProps, loadedState && props.children);
});
DeferredContent.displayName = 'DeferredContent';
exports.DeferredContent = DeferredContent;
Object.defineProperty(exports, '__esModule', { value: true });
return exports;
})({}, React, primereact.api, primereact.hooks, primereact.componentbase);
+1
View File
@@ -0,0 +1 @@
this.primereact=this.primereact||{},this.primereact.deferredcontent=function(e,t,r,n,o){"use strict";function u(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var a=u(t);function i(e){if(Array.isArray(e))return e}function c(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,u,a,i=[],c=!0,l=!1;try{if(u=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;c=!1}else for(;!(c=(n=u.call(r)).done)&&(i.push(n.value),i.length!==t);c=!0);}catch(e){l=!0,o=e}finally{try{if(!c&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(l)throw o}}return i}}function l(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function f(e,t){if(e){if("string"==typeof e)return l(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?l(e,t):void 0}}function s(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function d(e,t){return i(e)||c(e,t)||f(e,t)||s()}var p=o.ComponentBase.extend({defaultProps:{__TYPE:"DeferredContent",onload:null,children:void 0}}),m=a.forwardRef((function(e,t){var o=n.useMergeProps(),u=a.useContext(r.PrimeReactContext),i=p.getProps(e,u),c=d(a.useState(!1),2),l=c[0],f=c[1],s=a.useRef(null),m=d(n.useEventListener({target:"window",type:"scroll",listener:function(){h()&&(g(),v())}}),2),y=m[0],v=m[1],b=p.setMetaData({props:i,state:{loaded:l}}).ptm,h=function(){if(l)return!1;var e=s.current.getBoundingClientRect();return document.documentElement.clientHeight>=e.top},g=function(e){f(!0),i.onLoad&&i.onLoad(e)};a.useImperativeHandle(t,(function(){return{props:i,getElement:function(){return s.current}}})),n.useMountEffect((function(){l||(h()?g():y())}));var O=o({ref:s},p.getOtherProps(i),b("root"));return a.createElement("div",O,l&&i.children)}));return m.displayName="DeferredContent",e.DeferredContent=m,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.hooks,primereact.componentbase);
+7
View File
@@ -0,0 +1,7 @@
{
"main": "./deferredcontent.cjs.js",
"module": "./deferredcontent.esm.js",
"unpkg": "./deferredcontent.min.js",
"types": "./deferredcontent.d.ts",
"sideEffects": false
}