Sindbad~EG File Manager

Current Path : /home/frekansk/www/wp-content/plugins/learnpress/assets/src/js/frontend/profile/
Upload File :
Current File : //home/frekansk/www/wp-content/plugins/learnpress/assets/src/js/frontend/profile/course-tab.js

import { lpAddQueryArgs, lpFetchAPI } from '../../utils.js';

// Rest API load content course enrolled, created - Nhamdv.
const courseTab = () => {
	const elements = document.querySelectorAll( '.learn-press-course-tab__filter__content' );

	const getResponse = ( ele, dataset, append = false, viewMoreEle = false ) => {
		let url = lpData.lp_rest_url + 'lp/v1/profile/course-tab';
		url = lpAddQueryArgs( url, dataset );

		const callBack = {
			success: ( response ) => {
				const skeleton = ele.querySelector( '.lp-skeleton-animation' );
				skeleton && skeleton.remove();

				if ( response.status === 'success' && response.data ) {
					if ( append ) {
						ele.innerHTML += response.data;
					} else {
						ele.innerHTML = response.data;
					}
				} else if ( append ) {
					ele.innerHTML += `<div class="lp-ajax-message" style="display:block">${ response.message && response.message }</div>`;
				} else {
					ele.innerHTML = `<div class="lp-ajax-message" style="display:block">${ response.message && response.message }</div>`;
				}

				if ( viewMoreEle ) {
					viewMoreEle.classList.remove( 'loading' );

					const paged = parseInt( viewMoreEle.dataset.paged );
					const numberPage = parseInt( viewMoreEle.dataset.number );

					if ( numberPage <= paged ) {
						viewMoreEle.remove();
					}

					viewMoreEle.dataset.paged = paged + 1;
				}

				viewMore( ele, dataset );
			},
			error: ( error ) => {
				console.log( error );
			},
			completed: () => {

			},
		};

		let paramsFetch = {};

		if ( 0 !== parseInt( lpData.user_id ) ) {
			paramsFetch = {
				headers: {
					'X-WP-Nonce': lpData.nonce,
				},
			};
		}

		lpFetchAPI( url, paramsFetch, callBack );
	};

	if ( 'IntersectionObserver' in window ) {
		const eleObserver = new IntersectionObserver( ( entries, observer ) => {
			entries.forEach( ( entry ) => {
				if ( entry.isIntersecting ) {
					const ele = entry.target;

					const params = ele.parentNode.querySelector( '.lp_profile_tab_input_param' );
					const data = { ...JSON.parse( params.value ), status: ele.dataset.tab || '' };

					getResponse( ele, data );

					eleObserver.unobserve( ele );
				}
			} );
		} );

		[ ...elements ].map( ( ele ) => {
			if ( ele.dataset.tab !== 'all' ) {
				eleObserver.observe( ele );
			} else {
				const params = ele.parentNode.querySelector( '.lp_profile_tab_input_param' );
				const data = { ...JSON.parse( params.value ), status: ele.dataset.tab === 'all' ? '' : ele.dataset.tab || '' };

				getResponse( ele, data );
			}
		} );
	}

	const changeFilter = () => {
		const tabs = document.querySelectorAll( '.learn-press-course-tab-filters' );

		tabs.forEach( ( tab ) => {
			const filters = tab.querySelectorAll( '.learn-press-filters a' );

			filters.forEach( ( filter ) => {
				filter.addEventListener( 'click', ( e ) => {
					e.preventDefault();

					const tabName = filter.dataset.tab;

					[ ...filters ].map( ( ele ) => {
						ele.classList.remove( 'active' );
					} );

					filter.classList.add( 'active' );

					[ ...tab.querySelectorAll( '.learn-press-course-tab__filter__content' ) ].map( ( ele ) => {
						ele.style.display = 'none';

						if ( ele.dataset.tab === tabName ) {
							ele.style.display = '';
						}
					} );
				} );
			} );
		} );
	};

	changeFilter();

	const viewMore = ( ele, dataset ) => {
		const viewMoreEle = ele.querySelector( 'button[data-paged]' );

		if ( viewMoreEle ) {
			viewMoreEle.addEventListener( 'click', ( e ) => {
				e.preventDefault();

				const paged = viewMoreEle && viewMoreEle.dataset.paged;

				viewMoreEle.classList.add( 'loading' );

				const element = dataset.layout === 'list' ? '.lp_profile_course_progress' : '.learn-press-courses';

				getResponse( ele.querySelector( element ), { ...dataset, ...{ paged } }, true, viewMoreEle );
			} );
		}
	};
};
export default courseTab;

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists