File

src/app/resources/resources.component.ts

Implements

OnInit AfterViewInit OnDestroy FrameworkSelectionActionsDelegate OnTabViewWillEnter

Metadata

Index

Properties
Methods

Constructor

constructor(profileService: ProfileService, eventsBusService: EventsBusService, frameworkUtilService: FrameworkUtilService, frameworkService: FrameworkService, contentService: ContentService, preferences: SharedPreferences, splaschreenDeeplinkActionHandlerDelegate: SplaschreenDeeplinkActionHandlerDelegate, ngZone: NgZone, qrScanner: SunbirdQRScanner, events: Events, appGlobalService: AppGlobalService, appVersion: AppVersion, network: Network, telemetryGeneratorService: TelemetryGeneratorService, commonUtilService: CommonUtilService, formAndFrameworkUtilService: FormAndFrameworkUtilService, translate: TranslateService, toastController: ToastController, menuCtrl: MenuController, headerService: AppHeaderService, navService: NavigationService, router: Router, changeRef: ChangeDetectorRef, appNotificationService: NotificationService, popoverCtrl: PopoverController, frameworkSelectionDelegateService: FrameworkSelectionDelegateService, contentAggregatorHandler: ContentAggregatorHandler, profileHandler: ProfileHandler)
Parameters :
Name Type Optional
profileService ProfileService No
eventsBusService EventsBusService No
frameworkUtilService FrameworkUtilService No
frameworkService FrameworkService No
contentService ContentService No
preferences SharedPreferences No
splaschreenDeeplinkActionHandlerDelegate SplaschreenDeeplinkActionHandlerDelegate No
ngZone NgZone No
qrScanner SunbirdQRScanner No
events Events No
appGlobalService AppGlobalService No
appVersion AppVersion No
network Network No
telemetryGeneratorService TelemetryGeneratorService No
commonUtilService CommonUtilService No
formAndFrameworkUtilService FormAndFrameworkUtilService No
translate TranslateService No
toastController ToastController No
menuCtrl MenuController No
headerService AppHeaderService No
navService NavigationService No
router Router No
changeRef ChangeDetectorRef No
appNotificationService NotificationService No
popoverCtrl PopoverController No
frameworkSelectionDelegateService FrameworkSelectionDelegateService No
contentAggregatorHandler ContentAggregatorHandler No
profileHandler ProfileHandler No

Methods

Async appTutorialScreen
appTutorialScreen()
Returns : any
arrangeMediumsByUserData
arrangeMediumsByUserData(categoryMediumsParam)
Parameters :
Name Optional
categoryMediumsParam No
Returns : void
classClickEvent
classClickEvent(event, isClassClicked?: boolean)
Parameters :
Name Type Optional
event No
isClassClicked boolean Yes
Returns : void
classClickHandler
classClickHandler(index, isClassClicked?: boolean)
Parameters :
Name Type Optional
index No
isClassClicked boolean Yes
Returns : void
Async exploreOtherContents
exploreOtherContents()
Returns : any
generateClassInteractTelemetry
generateClassInteractTelemetry(currentClass: string, previousClass: string)
Parameters :
Name Type Optional
currentClass string No
previousClass string No
Returns : void
generateExtraInfoTelemetry
generateExtraInfoTelemetry(sectionsCount)
Parameters :
Name Optional
sectionsCount No
Returns : void
generateMediumInteractTelemetry
generateMediumInteractTelemetry(currentMedium: string, previousMedium: string)
Parameters :
Name Type Optional
currentMedium string No
previousMedium string No
Returns : void
generateNetworkType
generateNetworkType()
Returns : void
getCategoryData
getCategoryData()
Returns : void
Async getChannelId
getChannelId()
Returns : unknown
getCurrentUser
getCurrentUser()

It will fetch the guest user profile details

Returns : void
getGradeLevelData
getGradeLevelData(frameworkId, categories)
Parameters :
Name Optional
frameworkId No
categories No
Returns : any
Async getGroupByPage
getGroupByPage(isAfterLanguageChange)
Parameters :
Name Optional Default value
isAfterLanguageChange No false
Returns : any
Async getLocalContent
getLocalContent()
Returns : any
getMediumData
getMediumData(frameworkId, categories)
Parameters :
Name Optional
frameworkId No
categories No
Returns : any
getPopularContent
getPopularContent(isAfterLanguageChange, contentSearchCriteria?: ContentSearchCriteria)

Get popular content

Parameters :
Name Type Optional Default value
isAfterLanguageChange No false
contentSearchCriteria ContentSearchCriteria Yes
Returns : void
getSubjectData
getSubjectData(frameworkId, categories)
Parameters :
Name Optional
frameworkId No
categories No
Returns : any
handleHeaderEvents
handleHeaderEvents($event)
Parameters :
Name Optional
$event No
Returns : void
Private initNetworkDetection
initNetworkDetection()
Returns : void
Async ionViewDidEnter
ionViewDidEnter()
Returns : any
ionViewDidLeave
ionViewDidLeave()
Returns : void
Async ionViewWillEnter
ionViewWillEnter()
Returns : any
ionViewWillLeave
ionViewWillLeave()
Returns : void
launchContent
launchContent()
Returns : void
logScrollEnd
logScrollEnd(event)
Parameters :
Name Optional
event No
Returns : void
markLocallyAvailableTextBook
markLocallyAvailableTextBook()
Returns : void
mediumClickEvent
mediumClickEvent(event, isMediumClicked?: boolean)
Parameters :
Name Type Optional
event No
isMediumClicked boolean Yes
Returns : void
mediumClickHandler
mediumClickHandler(index: number, mediumName, isMediumClicked?: boolean)
Parameters :
Name Type Optional
index number No
mediumName No
isMediumClicked boolean Yes
Returns : void
navigateToDetailPage
navigateToDetailPage(event, sectionName)
Parameters :
Name Optional
event No
sectionName No
Returns : void
navigateToTextbookPage
navigateToTextbookPage(items, subject)
Parameters :
Name Optional
items No
subject No
Returns : void
navigateToViewMoreContentsPage
navigateToViewMoreContentsPage(section)
Parameters :
Name Optional
section No
Returns : void
ngAfterViewInit
ngAfterViewInit()
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
Async ngOnInit
ngOnInit()
Returns : any
onCourseCardClick
onCourseCardClick(event)
Parameters :
Name Optional
event No
Returns : void
Async onFrameworkSelectionSubmit
onFrameworkSelectionSubmit(formInput: any, formOutput: any, router: Router, commonUtilService: CommonUtilService, telemetryGeneratorService: TelemetryGeneratorService, corRelation: Array)
Parameters :
Name Type Optional
formInput any No
formOutput any No
router Router No
commonUtilService CommonUtilService No
telemetryGeneratorService TelemetryGeneratorService No
corRelation Array<CorrelationData> No
Returns : any
orderBySubject
orderBySubject(searchResults: any[])
Parameters :
Name Type Optional
searchResults any[] No
Returns : {}
redirectToActivedownloads
redirectToActivedownloads()
Returns : void
redirectToNotifications
redirectToNotifications()
Returns : void
Async requestMoreContent
requestMoreContent()
Returns : any
scanQRCode
scanQRCode()
Returns : void
scrollToTop
scrollToTop()
Returns : void
Async search
search()
Returns : any
subscribeSdkEvent
subscribeSdkEvent()
Returns : void
subscribeUtilityEvents
subscribeUtilityEvents()
Returns : void
swipeDownToRefresh
swipeDownToRefresh(refresher?, avoidRefreshList?)
Parameters :
Name Optional
refresher Yes
avoidRefreshList Yes
Returns : void
tabViewWillEnter
tabViewWillEnter()
Returns : void

Properties

appLabel
Type : string
audienceFilter
Type : []
Default value : []
cardDefaultImg
categoryGradeLevels
Type : any
categoryGradeLevelsArray
Type : []
Default value : []
categoryMediumNamesArray
Type : []
Default value : []
categoryMediums
Type : any
channelId
Type : string
classFilterLayout
Default value : LibraryFiltersLayout.ROUND
classSelected
Type : []
Default value : []
coachTimeout
Type : any
Public commonUtilService
Type : CommonUtilService
contentView
Type : ContentView
Decorators :
@ViewChild('contentView', {static: false})
courseCardType
Default value : CourseCardGridTypes
courseList
Type : []
Default value : []
current_index
Type : any
currentGrade
Type : any
currentMedium
Type : string
defaultImg
Type : string
dynamicResponse
Type : any
Private eventSubscription
Type : Subscription
Public formAndFrameworkUtilService
Type : FormAndFrameworkUtilService
getGroupByPageReq
Type : ContentSearchCriteria
Default value : { searchType: SearchType.SEARCH }
guestUser
Default value : false
headerObservable
Type : Subscription
Public imageSrcMap
Default value : new Map()
isOnBoardingCardCompleted
Default value : false
isUpgradePopoverShown
Default value : false
layoutName
Type : string
Default value : 'textbook'
layoutPopular
Default value : ContentCard.LAYOUT_POPULAR
layoutSavedContent
Default value : ContentCard.LAYOUT_SAVED_CONTENT
locallyDownloadResources
mediumFilterLayout
Default value : LibraryFiltersLayout.SQUARE

Common consumption

mediumsSelected
Type : []
Default value : []
Public menuCtrl
Type : MenuController
mode
Type : string
Default value : 'soft'
networkFlag
Type : boolean
Private Optional networkSubscription
Type : Subscription
offlineImg
pageApiLoader
Default value : true

Flag to show latest and popular course loader

pageFilterCallBack
Type : PageFilterCallback
pageLoadedSuccess
Default value : false
profile
Type : Profile
refresh
Type : boolean
refresher
Type : IonRefresher
Decorators :
@ViewChild('libraryRefresher', {static: false})
scrollEventRemover
Type : any
searchApiLoader
Default value : true

Flag to show latest and popular course loader

searchGroupingContents
Type : any
selectedLanguage
Type : string
Default value : 'en'
selectedValue
Type : Array<string>
Default value : []
showSignInCard
Default value : false
Public source
Default value : PageId.LIBRARY
storyAndWorksheets
Type : Array<any>
subjects
Type : any
subjectThemeAndIconsMap
Type : object
Default value : { Science: { background: '#FFD6EB', titleColor: '#FD59B3', icon: 'assets/imgs/sub_science.svg' }, Mathematics: { background: '#FFDFD9', titleColor: '#EA2E52', icon: 'assets/imgs/sub_math.svg' }, English: { background: '#DAFFD8', titleColor: '#218432', icon: 'assets/imgs/sub_english.svg' }, Social: { background: '#DAD4FF', titleColor: '#635CDC', icon: 'assets/imgs/sub_social.svg' }, Hindi: { background: '#C2E2E9', titleColor: '#07718A', icon: 'assets/imgs/sub_hindi.svg' }, Chemistry: { background: '#FFE59B', titleColor: '#8D6A00', icon: 'assets/imgs/sub_chemistry.svg' }, Geography: { background: '#C2ECE6', titleColor: '#149D88', icon: 'assets/imgs/sub_geography.svg' }, Sanskrit: { background: '#FFDFC7', titleColor: '#AD632D', icon: 'assets/imgs/sub_science.svg' }, }
Public toastController
Type : ToastController
Private tutorialPopover
userId
Type : string
import { animate, group, state, style, transition, trigger } from '@angular/animations';
import { AfterViewInit, ChangeDetectorRef, Component, Inject, NgZone, OnDestroy, OnInit, ViewChild } from '@angular/core';
import { NavigationExtras, Router } from '@angular/router';
import {
  AudienceFilter,
  ContentCard,
  ContentFilterConfig,
  EventTopics,
  ExploreConstants,
  PreferenceKey,
  PrimaryCategory, ProfileConstants,
  RouterLinks,
  Search, ViewMore
} from '@app/app/app.constant';
import { SbTutorialPopupComponent } from '@app/app/components/popups/sb-tutorial-popup/sb-tutorial-popup.component';
import { AppGlobalService } from '@app/services/app-global-service.service';
import { AppHeaderService } from '@app/services/app-header.service';
import { CommonUtilService } from '@app/services/common-util.service';
import { ContentAggregatorHandler } from '@app/services/content/content-aggregator-handler.service';
import { AggregatorPageType, Orientation } from '@app/services/content/content-aggregator-namespaces';
import { FormAndFrameworkUtilService } from '@app/services/formandframeworkutil.service';
import { NavigationService } from '@app/services/navigation-handler.service';
import { NotificationService } from '@app/services/notification.service';
import { ProfileHandler } from '@app/services/profile-handler';
import { SplaschreenDeeplinkActionHandlerDelegate } from '@app/services/sunbird-splashscreen/splaschreen-deeplink-action-handler-delegate';
import { SunbirdQRScanner } from '@app/services/sunbirdqrscanner.service';
import {
  CorReleationDataType,
  Environment,
  ID,
  ImpressionType,
  InteractSubtype,
  InteractType,
  PageId
} from '@app/services/telemetry-constants';
import { TelemetryGeneratorService } from '@app/services/telemetry-generator.service';
import { ContentUtil } from '@app/util/content-util';
import { applyProfileFilter } from '@app/util/filter.util';
import { AppVersion } from '@ionic-native/app-version/ngx';
import { Network } from '@ionic-native/network/ngx';
import { IonContent as ContentView, IonRefresher, MenuController, PopoverController, ToastController } from '@ionic/angular';
import { Events } from '@app/util/events';
import { TranslateService } from '@ngx-translate/core';
import { CsPrimaryCategory } from '@project-sunbird/client-services/services/content';
import { CourseCardGridTypes, LibraryFiltersLayout } from '@project-sunbird/common-consumption';
import forEach from 'lodash/forEach';
import has from 'lodash/has';
import { Subscription } from 'rxjs';
import {
  CategoryTerm,
  ContentAggregatorRequest,
  ContentEventType,
  ContentRequest,
  ContentSearchCriteria,
  ContentService,
  CorrelationData,
  EventsBusEvent,
  EventsBusService,
  FrameworkCategoryCode,
  FrameworkCategoryCodesGroup,
  FrameworkService,
  FrameworkUtilService,
  GetFrameworkCategoryTermsRequest,
  Profile,
  ProfileService,
  ProfileType,
  SearchType,
  SharedPreferences,
  SortOrder
} from 'sunbird-sdk';
import { animationGrowInTopRight } from '../animations/animation-grow-in-top-right';
import { animationShrinkOutTopRight } from '../animations/animation-shrink-out-top-right';
import {
  FrameworkSelectionActionsDelegate, FrameworkSelectionDelegateService
} from '../profile/framework-selection/framework-selection.page';
import { PageFilterCallback } from './../page-filter/page-filter.page';
import { OnTabViewWillEnter } from './../tabs/on-tab-view-will-enter';
import { FormConstants } from '../form.constants';

@Component({
  selector: 'app-resources',
  templateUrl: './resources.component.html',
  styleUrls: ['./resources.component.scss'],
  animations: [
    trigger('appear', [
      state('true', style({
        left: '{{left_indent}}',
      }), { params: { left_indent: 0 } }), // default parameters values required
      
      transition('* => active', [
        style({ width: 5, opacity: 0 }),
        group([
          animate('0.3s 0.2s ease', style({
            transform: 'translateX(0) scale(1.2)', width: '*',
          })),
          animate('0.2s ease', style({
            opacity: 1
          }))
        ])
      ]),
    ]),
    trigger('ScrollHorizontal', [
      state('true', style({
        left: '{{left_indent}}',
        transform: 'translateX(-100px)',
      }), { params: { left_indent: 0 } }), // default parameters values required

      transition('* => active', [
        // style({ width: 5, transform: 'translateX(-100px)', opacity: 0 }),
        group([
          animate('0.3s 0.5s ease', style({
            transform: 'translateX(-100px)'
          })),
          animate('0.3s ease', style({
            opacity: 1
          }))
        ])
      ]),
    ])
  ]
})
export class ResourcesComponent implements OnInit, AfterViewInit, OnDestroy, FrameworkSelectionActionsDelegate, OnTabViewWillEnter {
  @ViewChild('libraryRefresher', { static: false }) refresher: IonRefresher;

  pageLoadedSuccess = false;
  storyAndWorksheets: Array<any>;
  selectedValue: Array<string> = [];
  guestUser = false;
  showSignInCard = false;
  userId: string;

  /**
   * Common consumption
   */
  mediumFilterLayout = LibraryFiltersLayout.SQUARE;
  classFilterLayout = LibraryFiltersLayout.ROUND;
  cardDefaultImg;
  offlineImg;
  categoryMediumNamesArray = [];
  mediumsSelected = [];
  categoryGradeLevelsArray = [];
  classSelected = [];
  private networkSubscription?: Subscription;
  networkFlag: boolean;
  public imageSrcMap = new Map();

  /**
   * Flag to show latest and popular course loader
   */
  searchApiLoader = true;
  isOnBoardingCardCompleted = false;
  public source = PageId.LIBRARY;
  selectedLanguage = 'en';
  audienceFilter = [];
  profile: Profile;
  appLabel: string;
  mode = 'soft';
  pageFilterCallBack: PageFilterCallback;
  getGroupByPageReq: ContentSearchCriteria = {
    searchType: SearchType.SEARCH
  };

  layoutName = 'textbook';
  layoutPopular = ContentCard.LAYOUT_POPULAR;
  layoutSavedContent = ContentCard.LAYOUT_SAVED_CONTENT;
  categoryGradeLevels: any;
  categoryMediums: any;
  current_index: any;
  currentGrade: any;
  currentMedium: string;
  defaultImg: string;
  isUpgradePopoverShown = false;

  refresh: boolean;
  private eventSubscription: Subscription;

  headerObservable: Subscription;
  scrollEventRemover: any;
  subjects: any;
  searchGroupingContents: any;
  /**
   * Flag to show latest and popular course loader
   */
  pageApiLoader = true;
  dynamicResponse: any;
  courseCardType = CourseCardGridTypes;
  @ViewChild('contentView', { static: false }) contentView: ContentView;
  locallyDownloadResources;
  channelId: string;
  coachTimeout: any;
  courseList = [];
  subjectThemeAndIconsMap = {
    Science: {
      background: '#FFD6EB',
      titleColor: '#FD59B3',
      icon: 'assets/imgs/sub_science.svg'
    },
    Mathematics: {
      background: '#FFDFD9',
      titleColor: '#EA2E52',
      icon: 'assets/imgs/sub_math.svg'
    },
    English: {
      background: '#DAFFD8',
      titleColor: '#218432',
      icon: 'assets/imgs/sub_english.svg'
    },
    Social: {
      background: '#DAD4FF',
      titleColor: '#635CDC',
      icon: 'assets/imgs/sub_social.svg'
    },
    Hindi: {
      background: '#C2E2E9',
      titleColor: '#07718A',
      icon: 'assets/imgs/sub_hindi.svg'
    },
    Chemistry: {
      background: '#FFE59B',
      titleColor: '#8D6A00',
      icon: 'assets/imgs/sub_chemistry.svg'
    },
    Geography: {
      background: '#C2ECE6',
      titleColor: '#149D88',
      icon: 'assets/imgs/sub_geography.svg'
    },
    Sanskrit: {
      background: '#FFDFC7',
      titleColor: '#AD632D',
      icon: 'assets/imgs/sub_science.svg'
    },
  };

  private tutorialPopover;

  constructor(
    @Inject('PROFILE_SERVICE') private profileService: ProfileService,
    @Inject('EVENTS_BUS_SERVICE') private eventsBusService: EventsBusService,
    @Inject('FRAMEWORK_UTIL_SERVICE') private frameworkUtilService: FrameworkUtilService,
    @Inject('FRAMEWORK_SERVICE') private frameworkService: FrameworkService,
    @Inject('CONTENT_SERVICE') private contentService: ContentService,
    @Inject('SHARED_PREFERENCES') private preferences: SharedPreferences,
    private splaschreenDeeplinkActionHandlerDelegate: SplaschreenDeeplinkActionHandlerDelegate,
    private ngZone: NgZone,
    private qrScanner: SunbirdQRScanner,
    private events: Events,
    private appGlobalService: AppGlobalService,
    private appVersion: AppVersion,
    private network: Network,
    private telemetryGeneratorService: TelemetryGeneratorService,
    public commonUtilService: CommonUtilService,
    public formAndFrameworkUtilService: FormAndFrameworkUtilService,
    private translate: TranslateService,
    public toastController: ToastController,
    public menuCtrl: MenuController,
    private headerService: AppHeaderService,
    private navService: NavigationService,
    private router: Router,
    private changeRef: ChangeDetectorRef,
    private appNotificationService: NotificationService,
    private popoverCtrl: PopoverController,
    private frameworkSelectionDelegateService: FrameworkSelectionDelegateService,
    private contentAggregatorHandler: ContentAggregatorHandler,
    private profileHandler: ProfileHandler
  ) {
    this.preferences.getString(PreferenceKey.SELECTED_LANGUAGE_CODE).toPromise()
      .then(val => {
        if (val && val.length) {
          this.selectedLanguage = val;
        }
      });
    this.subscribeUtilityEvents();
    this.appVersion.getAppName()
      .then((appName: any) => {
        this.appLabel = appName;
      });
    this.defaultImg = this.commonUtilService.convertFileSrc('assets/imgs/ic_launcher.png');
    this.cardDefaultImg = this.commonUtilService.convertFileSrc('assets/imgs/ic_launcher.png');
    this.offlineImg = this.commonUtilService.convertFileSrc('assets/imgs/ic_offline_white_sm.png');
    this.generateNetworkType();

  }

  subscribeUtilityEvents() {
    this.profileService.getActiveSessionProfile({ requiredFields: ProfileConstants.REQUIRED_FIELDS }).subscribe((profile: Profile) => {
      this.profile = profile;
    });
    this.events.subscribe('savedResources:update', (res) => {
      if (res && res.update) {
        this.getLocalContent();
      }
    });
    this.events.subscribe('event:showScanner', (data) => {
      if (data.pageName === PageId.LIBRARY) {
        this.qrScanner.startScanner(PageId.LIBRARY, false);
      }
    });
    this.events.subscribe('onAfterLanguageChange:update', (res) => {
      if (res && res.selectedLanguage) {
        this.selectedLanguage = res.selectedLanguage;
        this.getPopularContent(true);
      }
    });

    this.events.subscribe(AppGlobalService.PROFILE_OBJ_CHANGED, () => {
      this.swipeDownToRefresh(false, true);
    });

    // Event for optional and forceful upgrade
    this.events.subscribe('force_optional_upgrade', async (upgrade) => {
      if (upgrade && !this.isUpgradePopoverShown) {
        await this.appGlobalService.openPopover(upgrade);
        this.isUpgradePopoverShown = true;
      }
    });
  }

  async ngOnInit() {
    const isFirstTimeOnboarding = await this.preferences.getBoolean(PreferenceKey.COACH_MARK_SEEN).toPromise();
    if (!isFirstTimeOnboarding) {
      this.telemetryGeneratorService.generateImpressionTelemetry(
        ImpressionType.PAGE_REQUEST, '',
        PageId.LIBRARY,
        Environment.ONBOARDING
      );
    }
    this.getCurrentUser();
    this.initNetworkDetection();
    this.appGlobalService.generateConfigInteractEvent(PageId.LIBRARY, this.isOnBoardingCardCompleted);
    this.appNotificationService.handleNotification();

    this.events.subscribe(EventTopics.TAB_CHANGE, (data: string) => {
      this.scrollToTop();
      if (data === '') {
        this.qrScanner.startScanner(this.appGlobalService.getPageIdForTelemetry());
      }
    });

  }

  generateNetworkType() {
    const values = {};
    values['network-type'] = this.network.type;
    this.telemetryGeneratorService.generateExtraInfoTelemetry(
      values,
      PageId.LIBRARY
    );
  }

  ngAfterViewInit() {
    this.events.subscribe('onboarding-card:completed', (param) => {
      this.isOnBoardingCardCompleted = param.isOnBoardingCardCompleted;
    });
  }

  ionViewWillLeave(): void {
    this.refresher.disabled = true;
    if (this.eventSubscription) {
      this.eventSubscription.unsubscribe();
    }
    this.events.unsubscribe('update_header');
    this.events.unsubscribe('onboarding-card:completed');
    if (this.headerObservable) {
      this.headerObservable.unsubscribe();
    }
  }

  ionViewDidLeave() {
    if (this.coachTimeout && this.coachTimeout.clearTimeout) {
      this.coachTimeout.clearTimeout();
    }
  }

  /**
   * It will fetch the guest user profile details
   */
  getCurrentUser(): void {
    this.guestUser = !this.appGlobalService.isUserLoggedIn();
    const profileType = this.appGlobalService.getGuestUserType();
    this.showSignInCard = false;

    if (this.guestUser) {
      this.showSignInCard = this.commonUtilService.isAccessibleForNonStudentRole(profileType);
      if (this.showSignInCard) {
        this.audienceFilter = AudienceFilter.GUEST_TEACHER;
      } else if (profileType === ProfileType.STUDENT) {
        this.audienceFilter = AudienceFilter.GUEST_STUDENT;
      }
    } else {
      this.audienceFilter = AudienceFilter.LOGGED_IN_USER;
    }

    this.profile = this.appGlobalService.getCurrentUser();
    this.getLocalContent();
  }

  /**
   * Get popular content
   */
  getPopularContent(isAfterLanguageChange = false, contentSearchCriteria?: ContentSearchCriteria) {
    this.storyAndWorksheets = [];
    this.searchApiLoader = true;

    if (!contentSearchCriteria) {
      contentSearchCriteria = {
        mode: 'hard'
      };
    }

    this.mode = contentSearchCriteria.mode;

    if (this.profile) {
      if (this.profile.board && this.profile.board.length) {
        contentSearchCriteria.board = applyProfileFilter(this.appGlobalService, this.profile.board,
          contentSearchCriteria.board, 'board');
      }

      if (this.profile.medium && this.profile.medium.length) {
        contentSearchCriteria.medium = applyProfileFilter(this.appGlobalService, this.profile.medium,
          contentSearchCriteria.medium, 'medium');
      }

      if (this.profile.grade && this.profile.grade.length) {
        contentSearchCriteria.grade = applyProfileFilter(this.appGlobalService, this.profile.grade,
          contentSearchCriteria.grade, 'gradeLevel');
      }

    }
    // swipe down to refresh should not over write current selected options
    if (contentSearchCriteria.grade) {
      this.getGroupByPageReq.grade = contentSearchCriteria.grade;
    }
    if (contentSearchCriteria.medium) {
      this.getGroupByPageReq.medium = contentSearchCriteria.medium;
    }
    if (contentSearchCriteria.board) {
      this.getGroupByPageReq.board = contentSearchCriteria.board;
    } else {
      this.getGroupByPageReq.channel = [this.channelId];
    }

    this.getGroupByPageReq.mode = 'hard';
    this.getGroupByPageReq.facets = Search.FACETS_ETB;
    this.getGroupByPageReq.primaryCategories = [CsPrimaryCategory.DIGITAL_TEXTBOOK];
    this.getGroupByPageReq.fields = ExploreConstants.REQUIRED_FIELDS;
    this.getGroupByPage(isAfterLanguageChange);
  }

  // Make this method as private
  async getGroupByPage(isAfterLanguageChange = false) {

    const selectedBoardMediumGrade = ((this.getGroupByPageReq.board && this.getGroupByPageReq.board.length
      && this.getGroupByPageReq.board[0]) ? this.getGroupByPageReq.board[0] + ', ' : '') +
      (this.getGroupByPageReq.medium && this.getGroupByPageReq.medium.length
        && this.getGroupByPageReq.medium[0]) + ' Medium, ' +
      (this.getGroupByPageReq.grade && this.getGroupByPageReq.grade.length && this.getGroupByPageReq.grade[0]);
    this.appGlobalService.setSelectedBoardMediumGrade(selectedBoardMediumGrade);

    this.storyAndWorksheets = [];
    this.searchApiLoader = !this.refresh;
    const reqvalues = {};
    reqvalues['pageReq'] = this.getGroupByPageReq;
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.OTHER,
      InteractSubtype.RESOURCE_PAGE_REQUEST,
      Environment.HOME,
      this.source, undefined,
      reqvalues);

    this.getGroupByPageReq.sortCriteria = [{
      sortAttribute: 'name',
      sortOrder: SortOrder.ASC
    }];
    const audience: string[] = await this.profileHandler.getAudience(this.profile.profileType);
    const request: ContentAggregatorRequest = {
      userPreferences: {
        board: this.getGroupByPageReq.board,
        medium: this.getGroupByPageReq.medium,
        gradeLevel: this.getGroupByPageReq.grade,
        subject: this.profile.subject,
      },
      applyFirstAvailableCombination: {
        medium: this.getGroupByPageReq.medium,
        gradeLevel: this.getGroupByPageReq.grade
      },
      interceptSearchCriteria: (contentSearchCriteria: ContentSearchCriteria) => {
        contentSearchCriteria.board = this.getGroupByPageReq.board;
        contentSearchCriteria.medium = this.getGroupByPageReq.medium;
        contentSearchCriteria.grade = this.getGroupByPageReq.grade;
        return contentSearchCriteria;
      }
    };
    // Get the book data
    try {
      this.dynamicResponse = await this.contentAggregatorHandler.aggregate(request, AggregatorPageType.LIBRARY);
      if (this.dynamicResponse) {
        this.dynamicResponse.forEach((val) => {
          if (val.theme && val.theme.orientation === Orientation.VERTICAL) {
            this.searchGroupingContents = val.data;
          }
        });
        this.dynamicResponse = this.contentAggregatorHandler.populateIcons(this.dynamicResponse);
      }
      const newSections = [];
      this.getCategoryData();
      this.searchGroupingContents.sections.forEach(section => {
        if (section.name) {
          if (has(section.name, this.selectedLanguage)) {
            const langs = [];
            forEach(section.name, (value, key) => {
              langs[key] = value;
            });
            section.name = langs[this.selectedLanguage];
          }
        }
        newSections.push(section);
      });
      if (this.profile.subject && this.profile.subject.length) {
        this.storyAndWorksheets = this.orderBySubject([...newSections]);
      } else {
        this.storyAndWorksheets = newSections;
      }
      this.pageLoadedSuccess = true;
      this.refresh = false;
      this.searchApiLoader = false;
      this.generateExtraInfoTelemetry(newSections.length);
    } catch (error) {
      this.ngZone.run(() => {
        this.refresh = false;
        this.searchApiLoader = false;
        if (error === 'SERVER_ERROR' || error === 'SERVER_AUTH_ERROR') {
          if (!isAfterLanguageChange) {
            this.commonUtilService.showToast('ERROR_FETCHING_DATA');
          }
        }
        const errValues = {};
        errValues['isNetworkAvailable'] = this.commonUtilService.networkInfo.isNetworkAvailable ? 'Y' : 'N';
        this.telemetryGeneratorService.generateInteractTelemetry(InteractType.OTHER,
          InteractSubtype.RESOURCE_PAGE_ERROR,
          Environment.HOME,
          this.source, undefined,
          errValues);
      });
    }
  }

  orderBySubject(searchResults: any[]) {
    let selectedSubject: string[];
    const filteredSubject: string[] = [];
    selectedSubject = applyProfileFilter(this.appGlobalService, this.profile.subject, selectedSubject, 'subject');

    for (let i = 0; i < selectedSubject.length; i++) {
      const index = searchResults.findIndex((el) => {
        return el.name.toLowerCase().trim() === selectedSubject[i].toLowerCase().trim();
      });
      if (index !== -1) {
        filteredSubject.push(searchResults.splice(index, 1)[0]);
      }
    }
    filteredSubject.push(...searchResults);
    return filteredSubject;
  }
  markLocallyAvailableTextBook() {
    if (!this.locallyDownloadResources || !this.storyAndWorksheets) {
      return;
    }
    for (let i = 0; i < this.locallyDownloadResources.length; i++) {
      for (let j = 0; j < this.storyAndWorksheets.length; j++) {
        for (let k = 0; k < this.storyAndWorksheets[j].contents.length; k++) {
          if (this.locallyDownloadResources[i].isAvailableLocally &&
            this.locallyDownloadResources[i].identifier === this.storyAndWorksheets[j].contents[k].identifier) {
            this.storyAndWorksheets[j].contents[k].isAvailableLocally = true;
          }
        }
      }
    }
  }

  generateExtraInfoTelemetry(sectionsCount) {
    const values = {};
    values['pageSectionCount'] = sectionsCount;
    values['networkAvailable'] = this.commonUtilService.networkInfo.isNetworkAvailable ? 'Y' : 'N';
    this.telemetryGeneratorService.generateExtraInfoTelemetry(
      values,
      PageId.LIBRARY
    );
  }

  async ionViewWillEnter() {
    this.events.subscribe('update_header', () => {
      this.headerService.showHeaderWithHomeButton(['search', 'download', 'notification']);
    });
    this.headerObservable = this.headerService.headerEventEmitted$.subscribe(eventName => {
      this.handleHeaderEvents(eventName);
    });
    this.headerService.showHeaderWithHomeButton(['search', 'download', 'notification']);

    this.getCategoryData();

    this.getCurrentUser();

    await this.getChannelId();

    if (!this.pageLoadedSuccess) {
      this.getPopularContent();
    }
    this.subscribeSdkEvent();

    this.splaschreenDeeplinkActionHandlerDelegate.isDelegateReady = true;
    const isFirstTimeOnboarding = await this.preferences.getBoolean(PreferenceKey.COACH_MARK_SEEN).toPromise();
    if (!isFirstTimeOnboarding) {
      this.telemetryGeneratorService.generatePageLoadedTelemetry(
        PageId.LIBRARY,
        Environment.ONBOARDING
      );
    }
  }

  async ionViewDidEnter() {
    this.refresher.disabled = false;
    const utilityConfigFields = await this.formAndFrameworkUtilService.getFormFields(FormConstants.UTILITY_CONFIG);
    if (utilityConfigFields.find(field => field.code === 'experienceSwitchPopupConfig').config.isEnabled) {
      this.coachTimeout = setTimeout(() => {
        this.appGlobalService.showNewTabsSwitchPopup();
       }, 2000);
    }
  }

  subscribeSdkEvent() {
    this.eventSubscription = this.eventsBusService.events().subscribe((event: EventsBusEvent) => {
      if (event.payload && event.type === ContentEventType.IMPORT_COMPLETED) {
        this.getLocalContent();
      }
    }) as any;
  }

  swipeDownToRefresh(refresher?, avoidRefreshList?) {
    this.refresh = true;
    this.storyAndWorksheets = [];

    this.getCurrentUser();
    if (refresher) {
      refresher.target.complete();
      this.telemetryGeneratorService.generatePullToRefreshTelemetry(PageId.LIBRARY, Environment.HOME);
      this.getGroupByPage(false);
    } else {
      this.getPopularContent(false, null);
    }
  }

  scanQRCode() {
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.QRCodeScanClicked,
      Environment.HOME,
      PageId.LIBRARY);
    this.qrScanner.startScanner(PageId.LIBRARY);
  }

  async search() {
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.SEARCH_BUTTON_CLICKED,
      Environment.HOME,
      PageId.LIBRARY);
    const primaryCategories = await this.formAndFrameworkUtilService.getSupportedContentFilterConfig(
      ContentFilterConfig.NAME_LIBRARY);
    this.router.navigate([RouterLinks.SEARCH], {
      state: {
        primaryCategories,
        source: PageId.LIBRARY,
        searchWithBackButton: true
      }
    });
  }

  getCategoryData() {
    const syllabus: Array<string> = this.appGlobalService.getCurrentUser().syllabus;
    const frameworkId = (syllabus && syllabus.length > 0) ? syllabus[0] : undefined;
    const categories: Array<FrameworkCategoryCode> = FrameworkCategoryCodesGroup.DEFAULT_FRAMEWORK_CATEGORIES;
    this.getMediumData(frameworkId, categories);
    this.getGradeLevelData(frameworkId, categories);
    this.getSubjectData(frameworkId, categories);
  }

  getSubjectData(frameworkId, categories): any {
    const req: GetFrameworkCategoryTermsRequest = {
      currentCategoryCode: FrameworkCategoryCode.SUBJECT,
      language: this.translate.currentLang,
      requiredCategories: categories,
      frameworkId
    };
    this.frameworkUtilService.getFrameworkCategoryTerms(req).toPromise()
      .then((res: CategoryTerm[]) => {
        this.subjects = res;
      });
  }

  getMediumData(frameworkId, categories): any {
    const req: GetFrameworkCategoryTermsRequest = {
      currentCategoryCode: FrameworkCategoryCode.MEDIUM,
      language: this.translate.currentLang,
      requiredCategories: categories,
      frameworkId
    };
    this.frameworkUtilService.getFrameworkCategoryTerms(req).toPromise()
      .then((res: CategoryTerm[]) => {
        this.categoryMediums = res;
        this.categoryMediumNamesArray = res.map(a => (a.name));
        this.arrangeMediumsByUserData([...this.categoryMediumNamesArray]);
      });
  }

  arrangeMediumsByUserData(categoryMediumsParam) {
    if (this.appGlobalService.getCurrentUser() &&
      this.appGlobalService.getCurrentUser().medium &&
      this.appGlobalService.getCurrentUser().medium.length) {
      const matchedIndex = this.categoryMediumNamesArray.map(x => x.toLocaleLowerCase())
        .indexOf(this.appGlobalService.getCurrentUser().medium[0].toLocaleLowerCase());
      for (let i = matchedIndex; i > 0; i--) {
        categoryMediumsParam[i] = categoryMediumsParam[i - 1];
        if (i === 1) {
          categoryMediumsParam[0] = this.categoryMediumNamesArray[matchedIndex];
        }
      }
      this.categoryMediumNamesArray = categoryMediumsParam;
      if (this.searchGroupingContents && this.searchGroupingContents.combination.medium) {
        const indexOfSelectedmediums = this.categoryMediumNamesArray.indexOf(this.searchGroupingContents.combination.medium);
        this.mediumClickHandler(indexOfSelectedmediums, this.categoryMediumNamesArray[indexOfSelectedmediums]);
      } else {
        for (let i = 0, len = this.categoryMediumNamesArray.length; i < len; i++) {
          if ((this.getGroupByPageReq.medium[0].toLowerCase().trim()) === this.categoryMediumNamesArray[i].toLowerCase().trim()) {
            this.mediumClickHandler(i, this.categoryMediumNamesArray[i]);
          }
        }
      }
    }
  }

  getGradeLevelData(frameworkId, categories): any {
    const req: GetFrameworkCategoryTermsRequest = {
      currentCategoryCode: FrameworkCategoryCode.GRADE_LEVEL,
      language: this.translate.currentLang,
      requiredCategories: categories,
      frameworkId
    };
    this.frameworkUtilService.getFrameworkCategoryTerms(req).toPromise()
      .then((res: CategoryTerm[]) => {
        this.categoryGradeLevels = res;
        this.categoryGradeLevelsArray = res.map(a => (a.name));
        if (this.searchGroupingContents && this.searchGroupingContents.combination.gradeLevel) {
          const indexOfselectedClass =
            this.categoryGradeLevelsArray.indexOf(this.searchGroupingContents.combination.gradeLevel);
          this.classClickHandler(indexOfselectedClass);
        } else {
          for (let i = 0, len = this.categoryGradeLevelsArray.length; i < len; i++) {
            if (this.getGroupByPageReq.grade[0] === this.categoryGradeLevelsArray[i]) {
              this.classClickHandler(i);
            }
          }
        }
      });
  }

  generateClassInteractTelemetry(currentClass: string, previousClass: string) {
    const values = {};
    values['currentSelected'] = currentClass;
    values['previousSelected'] = previousClass;
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.CLASS_CLICKED,
      Environment.HOME,
      PageId.LIBRARY,
      undefined,
      values);
  }

  generateMediumInteractTelemetry(currentMedium: string, previousMedium: string) {
    const values = {};
    values['currentSelected'] = currentMedium;
    values['previousSelected'] = previousMedium;
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.MEDIUM_CLICKED,
      Environment.HOME,
      PageId.LIBRARY,
      undefined,
      values);
  }

  classClickEvent(event, isClassClicked?: boolean) {
    this.classClickHandler(event.data.index, isClassClicked);
  }

  classClickHandler(index, isClassClicked?: boolean) {
    if (isClassClicked) {
      this.generateClassInteractTelemetry(this.categoryGradeLevelsArray[index], this.getGroupByPageReq.grade[0]);
    }
    this.getGroupByPageReq.grade = [this.categoryGradeLevelsArray[index]];

    if ((this.currentGrade) && (this.currentGrade !== this.categoryGradeLevelsArray[index]) && isClassClicked) {
      this.dynamicResponse = [];
      this.getGroupByPage(false);
    }

    for (let i = 0, len = this.categoryGradeLevelsArray.length; i < len; i++) {
      if (i === index) {
        this.currentGrade = this.categoryGradeLevelsArray[i];
        this.current_index = this.categoryGradeLevels[i];
        this.categoryGradeLevels[i].selected = 'classAnimate';
      } else {
        this.categoryGradeLevels[i].selected = '';
      }
    }
    this.classSelected = [index];
    let el: HTMLElement | null = document.getElementById('class' + index);
    if (el) {
      el.scrollIntoView({ behavior: 'smooth', block: 'end', inline: 'start' });
    } else {
      setTimeout(() => {
        el = document.getElementById('class' + index);
        if (el) {
          el.scrollIntoView({ behavior: 'smooth', block: 'end', inline: 'start' });
        }
      }, 1000);
    }
  }

  mediumClickEvent(event, isMediumClicked?: boolean) {
    this.mediumClickHandler(event.data.index, event.data.text, isMediumClicked);
  }

  mediumClickHandler(index: number, mediumName, isMediumClicked?: boolean) {
    if (isMediumClicked) {
      this.generateMediumInteractTelemetry(mediumName, this.getGroupByPageReq.medium[0]);
    }
    this.getGroupByPageReq.medium = [mediumName];
    if (this.currentMedium !== mediumName && isMediumClicked) {
      this.dynamicResponse = [];
      this.getGroupByPage(false);
    }
    for (let i = 0, len = this.categoryMediumNamesArray.length; i < len; i++) {
      if (this.categoryMediumNamesArray[i] === mediumName) {
        this.currentMedium = this.categoryMediumNamesArray[i];
      }
    }
    this.mediumsSelected = [index];
    setTimeout(() => {
      const el = document.getElementById('medium' + index);
      if (el) {
        el.scrollIntoView({ behavior: 'smooth', block: 'end', inline: 'start' });
      }
    }, 1000);
  }

  navigateToDetailPage(event, sectionName) {
    event.data = event.data.content ? event.data.content : event.data;
    const item = event.data;
    const index = event.index;
    const identifier = item.contentId || item.identifier;
    const corRelationList = [{ id: sectionName || '', type: CorReleationDataType.SECTION }];
    const values = {};
    values['sectionName'] = sectionName;
    values['positionClicked'] = index;
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.CONTENT_CLICKED,
      Environment.HOME,
      PageId.LIBRARY,
      ContentUtil.getTelemetryObject(item),
      values,
      ContentUtil.generateRollUp(undefined, identifier),
      corRelationList);
    if (this.commonUtilService.networkInfo.isNetworkAvailable || item.isAvailableLocally) {
      this.navService.navigateToDetailPage(item, { content: item, corRelation: corRelationList });
    } else {
      this.commonUtilService.presentToastForOffline('OFFLINE_WARNING_ETBUI');
    }
  }

  navigateToTextbookPage(items, subject) {
    this.telemetryGeneratorService.generateInteractTelemetry(InteractType.TOUCH,
      InteractSubtype.VIEW_MORE_CLICKED,
      Environment.HOME,
      PageId.LIBRARY,
      ContentUtil.getTelemetryObject(items));
    if (this.commonUtilService.networkInfo.isNetworkAvailable || items.isAvailableLocally) {

      this.router.navigate([RouterLinks.TEXTBOOK_VIEW_MORE], {
        state: {
          contentList: items,
          subjectName: subject
        }
      });
    } else {
      this.commonUtilService.presentToastForOffline('OFFLINE_WARNING_ETBUI');
    }
  }

  launchContent() {
    this.router.navigate([RouterLinks.PLAYER]);
  }

  handleHeaderEvents($event) {
    switch ($event.name) {
      case 'search':
        this.search();
        break;
      case 'download':
        this.redirectToActivedownloads();
        break;
      case 'notification':
        this.redirectToNotifications();
        break;
      // case 'information':
      //   this.appTutorialScreen();
      //   break;
      default: console.warn('Use Proper Event name');
    }
  }

  async appTutorialScreen() {
    this.telemetryGeneratorService.generateInteractTelemetry(
      InteractType.TOUCH,
      InteractSubtype.INFORMATION_ICON_CLICKED,
      Environment.HOME,
      PageId.LIBRARY
    );
    this.tutorialPopover = await this.popoverCtrl.create({
      component: SbTutorialPopupComponent,
      componentProps: { appLabel: this.appLabel },
      enterAnimation: animationGrowInTopRight,
      leaveAnimation: animationShrinkOutTopRight,
      backdropDismiss: false,
      showBackdrop: true
    });
    this.tutorialPopover.present();
  }

  redirectToActivedownloads() {
    this.telemetryGeneratorService.generateInteractTelemetry(
      InteractType.TOUCH,
      InteractSubtype.ACTIVE_DOWNLOADS_CLICKED,
      Environment.HOME,
      PageId.LIBRARY);
    this.router.navigate([RouterLinks.ACTIVE_DOWNLOADS]);
  }

  redirectToNotifications() {
    this.telemetryGeneratorService.generateInteractTelemetry(
      InteractType.TOUCH,
      InteractSubtype.NOTIFICATION_CLICKED,
      Environment.HOME,
      PageId.LIBRARY);
    this.router.navigate([RouterLinks.NOTIFICATION]);
  }

  logScrollEnd(event) {
    // Added Telemetry on reaching Vertical Scroll End
    if (event && event.target.scrollHeight <= event.target.scrollTop + event.target.offsetHeight) {
      this.telemetryGeneratorService.generateInteractTelemetry(InteractType.SCROLL,
        InteractSubtype.BOOK_LIST_END_REACHED,
        Environment.HOME,
        this.source
      );
    }
  }

  scrollToTop() {
    this.contentView.scrollToTop();
  }

  async exploreOtherContents() {
    const navigationExtras = {
      state: {
        subjects: [...this.subjects],
        categoryGradeLevels: this.categoryGradeLevels,
        storyAndWorksheets: this.storyAndWorksheets,
        primaryCategories: PrimaryCategory.FOR_LIBRARY_TAB,
        selectedGrade: this.getGroupByPageReq.grade,
        selectedMedium: this.getGroupByPageReq.medium
      }
    };
    this.router.navigate([RouterLinks.EXPLORE_BOOK], navigationExtras);

    const corRelationList: Array<CorrelationData> = [];
    corRelationList.push({ id: this.profile.board ? this.profile.board.join(',') : '', type: CorReleationDataType.BOARD });
    corRelationList.push({ id: this.currentGrade ? this.currentGrade : '', type: CorReleationDataType.CLASS });
    corRelationList.push({ id: this.currentMedium ? this.currentMedium : '', type: CorReleationDataType.MEDIUM });

    this.telemetryGeneratorService.generateInteractTelemetry(
      this.storyAndWorksheets.length === 0 ? InteractType.WITHOUT_CONTENT : InteractType.WITH_CONTENT,
      '',
      Environment.LIBRARY,
      PageId.LIBRARY,
      undefined,
      undefined, undefined, corRelationList,
      ID.SEE_MORE_CONTENT_BUTTON_CLICKED);
  }

  async getLocalContent() {
    this.locallyDownloadResources = [];

    const requestParams: ContentRequest = {
      uid: this.profile ? this.profile.uid : undefined,
      primaryCategories: [],
      audience: this.audienceFilter,
      recentlyViewed: false,
    };
    this.contentService.getContents(requestParams).subscribe((data) => {
      this.ngZone.run(() => {
        this.locallyDownloadResources = data;
      });
    });
  }

  async getChannelId() {
    return this.frameworkService.getActiveChannelId().subscribe((data) => {
      this.channelId = data;
    });
  }

  private initNetworkDetection() {
    this.networkFlag = this.commonUtilService.networkInfo.isNetworkAvailable;
    this.networkSubscription = this.commonUtilService.networkAvailability$.subscribe(async (available: boolean) => {
      if (this.networkFlag !== available) {
        if (this.storyAndWorksheets.length) {
          for (let i = 0, leng = this.storyAndWorksheets.length; i < leng; i++) {
            for (let k = 0, len = this.storyAndWorksheets[i].contents.length; k < len; k++) {
              const content = this.storyAndWorksheets[i].contents[k];
              if (content.appIcon) {
                if (content.appIcon.includes('http:') || content.appIcon.includes('https:')) {
                  if (!this.commonUtilService.networkInfo.isNetworkAvailable) {
                    this.imageSrcMap.set(content.identifier, content.appIcon);
                    content.appIcon = this.defaultImg;
                  }
                } else if (content.basePath) {
                  content.appIcon = content.basePath + '/' + content.appIcon;
                }
              }
              if (!available) {
                // add custom attribute('cardImg') for common consumption
                if (!(!content.isAvailableLocally && !this.commonUtilService.networkInfo.isNetworkAvailable)) {
                  if (this.commonUtilService.convertFileSrc(content.courseLogoUrl)) {
                    this.storyAndWorksheets[i].contents[k].cardImg = this.commonUtilService.convertFileSrc(content.courseLogoUrl);
                  } else if (this.commonUtilService.convertFileSrc(content.appIcon)) {
                    this.storyAndWorksheets[i].contents[k].cardImg = this.commonUtilService.convertFileSrc(content.appIcon);
                  } else {
                    this.storyAndWorksheets[i].contents[k].cardImg = this.defaultImg;
                  }
                } else {
                  this.storyAndWorksheets[i].contents[k].cardImg = 'assets/imgs/ic_offline_white_sm.png';
                }
              } else {
                content.cardImg = this.commonUtilService.convertFileSrc(this.imageSrcMap.get(content.identifier));
                content.appIcon = this.commonUtilService.convertFileSrc(this.imageSrcMap.get(content.identifier));
              }
            }
          }
        }
      }
      this.networkFlag = available;
      this.storyAndWorksheets = [...this.storyAndWorksheets];
      this.changeRef.detectChanges();
    });
  }

  ngOnDestroy() {
    if (this.networkSubscription) {
      this.networkSubscription.unsubscribe();
    }
    if (this.headerObservable) {
      this.headerObservable.unsubscribe();
    }
    this.frameworkSelectionDelegateService.delegate = undefined;
  }

  onCourseCardClick(event) {
    const corRelationList: Array<CorrelationData> = [];
    corRelationList.push({ id: event.data.title || '', type: CorReleationDataType.SUBJECT });
    corRelationList.push({ id: (event.data.contents.length).toString(), type: CorReleationDataType.COURSE_COUNT });

    if (event.data.contents && event.data.contents.length > 1) {
      const appliedFilter = {
        board: this.getGroupByPageReq.board,
        medium: this.getGroupByPageReq.medium,
        gradeLevel: this.getGroupByPageReq.grade,
      };
      const curriculumCourseParams: NavigationExtras = {
        state: {
          theme: event.data.theme,
          titleColor: event.data.titleColor,
          subjectIcon: event.data.cardImg,
          subjectName: event.data.title,
          courseList: event.data.contents,
          corRelationList,
          appliedFilter
        }
      };
      this.telemetryGeneratorService.generateInteractTelemetry(
        InteractType.TOUCH,
        InteractSubtype.SUBJECT_CARD_CLICKED,
        Environment.HOME,
        PageId.LIBRARY,
        undefined,
        undefined,
        undefined,
        corRelationList
      );
      this.router.navigate([RouterLinks.CURRICULUM_COURSES], curriculumCourseParams);
    } else {
      this.telemetryGeneratorService.generateInteractTelemetry(
        InteractType.TOUCH,
        InteractSubtype.SUBJECT_CARD_CLICKED,
        Environment.HOME,
        PageId.LIBRARY,
        undefined,
        undefined,
        undefined,
        corRelationList
      );
      console.log('Content Data', event);
      this.navService.navigateToTrackableCollection(
        {
          content: event.data.contents[0],
          corRelation: corRelationList
        }
      );
    }
  }

  navigateToViewMoreContentsPage(section) {
    let navState = {};
    switch (section.dataSrc.type) {
      case 'TRACKABLE_COLLECTIONS':
        navState = {
          enrolledCourses: section.data.sections[0].contents,
          pageName: ViewMore.PAGE_COURSE_ENROLLED,
          headerTitle: this.commonUtilService.getTranslatedValue(section.title, ''),
          userId: this.appGlobalService.getUserId()
        };
        break;
      case 'CONTENTS':
      navState = {
        requestParams: {
          request: section.meta && section.meta.searchRequest
        },
        headerTitle: this.commonUtilService.getTranslatedValue(section.title, ''),
        pageName: ViewMore.PAGE_TV_PROGRAMS
      };
      break;
    }
    const params: NavigationExtras = {
      state: navState
    };
    this.router.navigate([RouterLinks.VIEW_MORE_ACTIVITY], params);
  }

  async requestMoreContent() {
    this.telemetryGeneratorService.generateInteractTelemetry(
      InteractType.TOUCH,
      InteractSubtype.LET_US_KNOW_CLICKED,
      Environment.LIBRARY,
      PageId.LIBRARY,
    );

    const formConfig = await this.formAndFrameworkUtilService.getContentRequestFormConfig();
    this.appGlobalService.formConfig = formConfig;
    this.frameworkSelectionDelegateService.delegate = this;
    this.router.navigate([`/${RouterLinks.PROFILE}/${RouterLinks.FRAMEWORK_SELECTION}`],
      {
        state: {
          showHeader: true,
          corRelation: [{ id: PageId.LIBRARY, type: CorReleationDataType.FROM_PAGE }],
          title: this.commonUtilService.translateMessage('FRMELEMNTS_LBL_REQUEST_CONTENT'),
          subTitle: this.commonUtilService.translateMessage('FRMELEMNTS_LBL_RELEVANT_CONTENT_SUB_HEADING'),
          formConfig,
          submitDetails: {
            label: this.commonUtilService.translateMessage('BTN_SUBMIT')
          }
        }
      });
  }

  async onFrameworkSelectionSubmit(formInput: any, formOutput: any, router: Router, commonUtilService: CommonUtilService,
    telemetryGeneratorService: TelemetryGeneratorService, corRelation: Array<CorrelationData>) {
    if (!commonUtilService.networkInfo.isNetworkAvailable) {
      await commonUtilService.showToast('OFFLINE_WARNING_ETBUI');
      return;
    }
    const selectedCorRelation: Array<CorrelationData> = [];

    if (formOutput['children']) {
      for (const key in formOutput['children']) {
        if (formOutput[key] && formOutput['children'][key]['other']) {
          formOutput[key] = formOutput['children'][key]['other'];
        }
      }

      delete formOutput['children'];
    }

    for (const key in formOutput) {
      if (typeof formOutput[key] === 'string') {
        selectedCorRelation.push({ id: formOutput[key], type: key });
      } else if (typeof formOutput[key] === 'object' && formOutput[key].name) {
        selectedCorRelation.push({ id: formOutput[key].name, type: key });
      }
    }
    telemetryGeneratorService.generateInteractTelemetry(
      InteractType.TOUCH,
      InteractSubtype.SUBMIT_CLICKED,
      Environment.HOME,
      PageId.FRAMEWORK_SELECTION,
      undefined,
      undefined,
      undefined,
      selectedCorRelation);
    const params = {
      formInput,
      formOutput,
      corRelation
    };
    router.navigate([`/${RouterLinks.RESOURCES}/${RouterLinks.RELEVANT_CONTENTS}`], { state: params });
  }

  tabViewWillEnter() {
    this.headerService.showHeaderWithHomeButton(['search', 'download', 'notification']);
  }
}
<ion-content hide-header-footer class="main-container avoid-bottom-tabs-space ui-container" (ionScrollEnd)="logScrollEnd($event)"
  scrollEvents="true" #contentView>
  <div slot="fixed" class="fixed-container">
    <sb-library-filters [list]="categoryMediumNamesArray" [selectedItems]="mediumsSelected"
      [layout]="mediumFilterLayout" (selectedFilter)="mediumClickEvent($event, true)">
    </sb-library-filters>
    <sb-library-filters [list]="categoryGradeLevelsArray" [selectedItems]="classSelected" [layout]="classFilterLayout"
      (selectedFilter)="classClickEvent($event, true);">
    </sb-library-filters>
  </div>
  <div class="scrollable-container">
    <ion-refresher #libraryRefresher slot="fixed" (ionRefresh)="swipeDownToRefresh($event)"></ion-refresher>
    <div *ngIf="!guestUser" style="padding-top: 5px;">
      <ng-container *ngIf="searchApiLoader && dynamicResponse && dynamicResponse.length === 0">
        <sb-course-cards-hlist [type]="courseCardType.MY_COURSE_RECENTLY_VIEWED_CARD_GRID" [isLoading]="searchApiLoader">
        </sb-course-cards-hlist>
      </ng-container>
    </div>
    <div *ngFor="let result of dynamicResponse; let i=index;">
      <div *ngIf="result?.theme && result?.theme?.orientation === 'horizontal'">
        <div *ngFor="let section of result?.data?.sections">
          <div *ngIf="result?.dataSrc?.type === 'TRACKABLE_COLLECTIONS'" style="padding-top: 5px;">
            <ng-container *ngIf="section.contents && section.contents.length">
              <sb-course-cards-hlist [title]="result?.name"
                [type]="courseCardType.MY_COURSE_RECENTLY_VIEWED_CARD_GRID" [contentList]="section.contents"
                [viewMoreButtonText]="'VIEW_ALL' | translate" (viewMoreClick)="navigateToViewMoreContentsPage(result)"
                (cardClick)="navigateToDetailPage($event, result?.name)" [hideProgress]="true"></sb-course-cards-hlist>
            </ng-container>
          </div>
          <div class="sb-recently-viewed-container" style="padding-bottom:40px;" *ngIf="section.contents?.length && (!result?.dataSrc || result?.dataSrc?.type!== 'TRACKABLE_COLLECTIONS')">
            <div class="sb-recently-viewed-items">
              <div class="sb-recenlty-viewed-title" role="heading" aria-level="2">{{result?.name}}
                <button class="sb-btn sb-btn-sm sb-btn-outline-info view-all-p8 ion-float-end"
                  (click)="navigateToViewMoreContentsPage(result);">
                  {{ 'VIEW_ALL' | translate }}</button>
              </div>

              <div class="sb-card-scroll-container" (scroll)='onScroll($event)'>
                <div class="sb-card-container sb-card-recently-container">
                  <div class="recently-viewed-card-size" *ngFor="let content of section.contents">
                    <sb-library-card
                      [isOffline]="!content?.isAvailableLocally && !commonUtilService.networkInfo.isNetworkAvailable"
                      [content]="content" [type]="'mobile_textbook'" [isLoading]="searchApiLoader"
                      (cardClick)="navigateToDetailPage($event, result?.name);"
                      [cardImg]="content?.cardImg || content?.appIcon || defaultAppIcon">
                    </sb-library-card>
                  </div>
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
      <div *ngIf="!result?.theme || result?.theme?.orientation === 'vertical'">
        <div class="section-header-style" role="heading" aria-level="2" *ngIf="result.data.sections.length">{{result.name}}</div>
        <div *ngFor="let section of result.data.sections">
          <div class="sb-textbook-container" *ngIf="section?.contents && section?.contents?.length">
            <sb-library-cards-stack [title]="section?.name" [contentList]="section?.contents"
              [isOffline]="!commonUtilService.networkInfo.isNetworkAvailable"
              [viewMoreButtonText]="'VIEW_MORE' | translate" [maxCardCount]="3"
              (viewMoreClick)="navigateToTextbookPage(section?.contents, section.name)"
              (cardClick)="navigateToDetailPage($event, section.name)">
            </sb-library-cards-stack>
          </div>
        </div>
      </div>
    </div>

    <ion-list class="m-n" *ngIf="searchApiLoader && storyAndWorksheets && storyAndWorksheets.length === 0">
      <app-skeleton-item height="16px" width="40%" style="padding: 16px;"></app-skeleton-item>
      <ion-item *ngFor="let i of [0,1,2,3,4,5,6,7,8]" class="animation-background">
        <ion-avatar item-start>
          <app-skeleton-item height="72px" width="72px"></app-skeleton-item>
        </ion-avatar>
        <ion-label style="padding-left: 40px;">
          <app-skeleton-item height="12px" width="67%" style="padding-bottom: 8px;"></app-skeleton-item>
          <app-skeleton-item height="12px" width="47%" style="padding-bottom: 8px;"></app-skeleton-item>
        </ion-label>
      </ion-item>
    </ion-list>
    <div class="sb-explore-container" *ngIf="storyAndWorksheets && storyAndWorksheets.length !== 0">
      <div class="text-center" *ngIf="commonUtilService?.networkInfo?.isNetworkAvailable">
        <p class="information">{{'FRMELEMNTS_LBL_COULD_NOT_FIND_CONTENT' | translate }}</p>
        <ion-button class="explore-more-books" expand="block" (click)="requestMoreContent()">
          {{'REQUEST_CONTENT' | translate}} </ion-button>
        <ion-button class="explore-more-content" expand="block" fill="outline" (click)="exploreOtherContents()">
          {{'SEE_MORE_BOOKS' | translate}} </ion-button>
      </div>
    </div>
    <div *ngIf="!searchApiLoader && storyAndWorksheets && storyAndWorksheets.length === 0">
      <div class="sb-nodownloads-container" *ngIf="commonUtilService?.networkInfo?.isNetworkAvailable">
        <div class="text-center">
          <img style="width: 30%;" src="./assets/imgs/group.svg" alt="">
        </div>
        <div class="text-center">
          <p class="sub-heading">{{'FRMELEMNTS_LBL_COULD_NOT_FIND_CONTENT' | translate }}</p>
          <ion-button class="explore-more-books" expand="block" (click)="requestMoreContent()">
            {{'REQUEST_CONTENT' | translate}} </ion-button>
          <ion-button class="explore-more-content" expand="block" fill="outline" (click)="exploreOtherContents()">
            {{'SEE_MORE_BOOKS' | translate}} </ion-button>
        </div>
      </div>
    </div>

    <div *ngIf="pageApiLoader && storyAndWorksheets && storyAndWorksheets.length === 0">
      <ion-list class="m-n" *ngIf="searchApiLoader && storyAndWorksheets && storyAndWorksheets.length === 0">
        <app-skeleton-item height="16px" width="40%" style="padding: 16px;"></app-skeleton-item>
        <ion-item *ngFor="let i of [0,1,2,3,4,5,6,7,8]" class="animation-background">
          <ion-avatar item-start>
            <app-skeleton-item height="72px" width="72px"></app-skeleton-item>
          </ion-avatar>
          <ion-label style="padding-left: 40px;">
            <app-skeleton-item height="12px" width="67%" style="padding-bottom: 8px;"></app-skeleton-item>
            <app-skeleton-item height="12px" width="47%" style="padding-bottom: 8px;"></app-skeleton-item>
          </ion-label>
        </ion-item>
      </ion-list>
    </div>

    <div class="ion-padding ion-text-center mt-32 mb-32" style="padding-top: 34px;"
      *ngIf="!commonUtilService?.networkInfo?.isNetworkAvailable">
      <img src="assets/imgs/outline-cloud_off.svg" alt="" />
      <ion-text>
        <h6 class="offline-header">
          <strong>{{ 'NO_INTERNET_TITLE' | translate }}</strong>
        </h6>
      </ion-text>
      <p class="offline-content">{{ 'OFFLINE_WARNING_ETBUI' | translate }}</p>
    </div>
  </div>

</ion-content>

./resources.component.scss

@import "src/assets/styles/variables";
@import "src/assets/styles/_custom-mixins";
@import "src/assets/styles/fonts";
@import "src/assets/styles/_variables.scss";

:host {
  div.scrollable-container {
    --background: $green !important;
  }
}

// :host {
.spinner-align {
  margin: 40px;
  padding-top: 30px;
}

.fixed-container {
  width: 100%;
  margin-top: 56px;
  position: relative;
  z-index: 2;
}

.scrollable-container {
  margin-top:108px;
  z-index: 1;
}

.main-container {
  background: map-get($colors, white);
  position: relative;
}

.offline-header {
  color: $gray-300;
  font-size: 1rem;
}

.offline-content {
  color: $gray-300 !important;
  width: 65%;
  margin: auto;
}

.view-all-p8 {
  padding: 0 $base-block-space !important;
}

#couchMark {
  position: fixed;
}

.animation-background {
  padding: 0 8px 0 8px;
  background-color: map-get($colors, white_f2);
}

.sb-view-more {
  background: $light-blue;
  text-align: center;
  padding: $base-block-space * 2;
  color: $primary-color;
  font-weight: bolder;
}

.explore-more-content {
  border-radius: 4px;
  --background: #{map-get($colors, white_f3)};
  --color: #{map-get($colors, deep_blue)};
  padding-left: 16px;
  padding-right: 16px;
  margin-top: 12px;
}

.explore-more-books {
  --background: #{$blue};
  border-radius: 4px;
  padding-left: 16px;
  padding-right: 16px;
}

.sub-heading {
  padding: 1em 4em !important;
  font-size: 0.75rem;
  color: $gray-300;
  margin: 0;
}

.sb-nodownloads-container {
  & {
    padding-top: 7rem;
  }
}

.sb-nodownloads-title {
  & {
    margin: 0;
    font-size: 1rem;
    padding-top: 4%;
    color: map-get($colors, granite_gray);
    font-weight: bold;
    letter-spacing: -0.46px
  }
}

.sb-explore-container {
  padding-bottom: 30px;
}

.sb--card-textbook-container {
  .sb--card {
    border-bottom: 0.5px solid rgba(151, 151, 151, 0.4);

    &:last-child {
      // .sb-card {
      border-bottom: none;
      // }
    }
  }
}

.textbook-icon {
  z-index: 1;
}

.sb-course-container {
  margin-top: 130px;

  .text-center {
    padding: 16px;
  }

  .sb-course-heading {
    background: map-get($colors , pale_blue);
    padding: 16px;
    font-size: 1.125rem;
    font-weight: bold;
    line-height: 1.125rem;

    .sb-nodownloads-container {
      & {
        padding-top: 4rem;
      }
    }
  }
}

#no-text-book {
  max-width: 50%;
  width: 50%;
}

.sb-card-recently-container {
  .recently-viewed-card-size{
    margin: 0 8px; 
    min-width:18rem;
    max-width:18rem;
    &:only-child {
      min-width: 100%;
      max-width: calc(100vw - 32px);
    }
  }
}
.course-card-pd{
  padding: 1px 0 12px;
}

.section-header-style{
  margin-left: 1rem;
  font-weight: 700;
  font-size: 1rem;
  padding-top: 1.5rem;
  padding-bottom: 4px;
}

.sb-recenlty-viewed-title{
  padding-left: 0 1rem !important;
  font-size: 1rem !important;
}
Legend
Html element
Component
Html element with directive

results matching ""

    No results matching ""