- Created complete documentation in docs/ directory - Added PROJECT_OVERVIEW.md with feature highlights and getting started guide - Added ARCHITECTURE.md with system design and technical details - Added SECURITY.md with comprehensive security implementation guide - Added DEVELOPMENT.md with development workflows and best practices - Added DEPLOYMENT.md with production deployment instructions - Added API.md with complete REST API documentation - Added CONTRIBUTING.md with contribution guidelines - Added CHANGELOG.md with version history and migration notes - Reorganized all documentation files into docs/ directory for better organization - Updated README.md with proper documentation links and quick navigation - Enhanced project structure with professional documentation standards
40 lines
1.2 KiB
JavaScript
40 lines
1.2 KiB
JavaScript
function getChildren(originalSlots, slidesRef, oldSlidesRef) {
|
|
if (originalSlots === void 0) {
|
|
originalSlots = {};
|
|
}
|
|
const slides = [];
|
|
const slots = {
|
|
'container-start': [],
|
|
'container-end': [],
|
|
'wrapper-start': [],
|
|
'wrapper-end': []
|
|
};
|
|
const getSlidesFromElements = (els, slotName) => {
|
|
if (!Array.isArray(els)) {
|
|
return;
|
|
}
|
|
els.forEach(vnode => {
|
|
const isFragment = typeof vnode.type === 'symbol';
|
|
if (slotName === 'default') slotName = 'container-end';
|
|
if (isFragment && vnode.children) {
|
|
getSlidesFromElements(vnode.children, 'default');
|
|
} else if (vnode.type && (vnode.type.name === 'SwiperSlide' || vnode.type.name === 'AsyncComponentWrapper')) {
|
|
slides.push(vnode);
|
|
} else if (slots[slotName]) {
|
|
slots[slotName].push(vnode);
|
|
}
|
|
});
|
|
};
|
|
Object.keys(originalSlots).forEach(slotName => {
|
|
if (typeof originalSlots[slotName] !== 'function') return;
|
|
const els = originalSlots[slotName]();
|
|
getSlidesFromElements(els, slotName);
|
|
});
|
|
oldSlidesRef.value = slidesRef.value;
|
|
slidesRef.value = slides;
|
|
return {
|
|
slides,
|
|
slots
|
|
};
|
|
}
|
|
export { getChildren }; |