src/app/modules/workspace/components/flagged/flagged.component.ts
The flagged submission component
                OnInit
                AfterViewInit
    
| selector | app-flagged | 
| templateUrl | ./flagged.component.html | 
| Properties | 
| 
 | 
| Methods | 
| constructor(searchService: SearchService, workSpaceService: WorkSpaceService, paginationService: PaginationService, activatedRoute: ActivatedRoute, route: Router, userService: UserService, config: ConfigService, resourceService: ResourceService, toasterService: ToasterService, navigationhelperService: NavigationHelperService) | ||||||||||||||||||||||||||||||||||||||||||||
| Constructor to create injected service(s) object Default method of Review submission Component class 
                                    Parameters :
                                     
 | 
| contentClick | ||||
| contentClick(param) | ||||
| This method launch the content editior 
                        Parameters :
                        
                         
 
                        Returns :          void | 
| fetchFlaggedContents | 
| fetchFlaggedContents(limit: number, pageNumber: number) | 
| This method sets the make an api call to get all reviewContent with page No and offset 
                        Returns :          void | 
| inview | ||||
| inview(event) | ||||
| get inview Data 
                        Parameters :
                        
                         
 
                        Returns :          void | 
| navigateToPage | ||||||||
| navigateToPage(page: number) | ||||||||
| This method helps to navigate to different pages. If page number is less than 1 or page number is greater than total number of pages is less which is not possible, then it returns. 
                        Parameters :
                        
                         
 
                        Example :
                         
                        Returns :      undefined | void | 
| ngAfterViewInit | 
| ngAfterViewInit() | 
| 
                        Returns :          void | 
| ngOnInit | 
| ngOnInit() | 
| 
                        Returns :          void | 
| delete | ||||
| delete(contentIds) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:111 | ||||
| Delete Api call . 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| getBatches | ||||
| getBatches(searchParams) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:128 | ||||
| Batchlist Api call 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| getChannelDetails | ||||
| getChannelDetails(channelId) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:164 | ||||
| get channel Api call 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| getLinkedCollections | ||||||
| getLinkedCollections(contentId: ContentIDParam) | ||||||
| Inherited from          WorkSpace | ||||||
| Defined in          WorkSpace:157 | ||||||
| search collection Api call 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| handleContentLockError | ||||
| handleContentLockError(errObj) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:142 | ||||
| handle content lock api error 
                        Parameters :
                        
                         
 
                        Returns :          string | 
| lockContent | ||||
| lockContent(content) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:97 | ||||
| this call will prepare reuest object and call lock api 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| removeContent | ||||||
| removeContent(contentList, requestData) | ||||||
| Inherited from          WorkSpace | ||||||
| Defined in          WorkSpace:120 | ||||||
| Method to remove content localcaly 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| search | ||||
| search(searchParams) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:33 | ||||
| Search Api call 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| searchContentWithLockStatus | ||||
| searchContentWithLockStatus(searchParams) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:40 | ||||
| Search Api call and returns contents with lock status of each one 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| UserList | ||||
| UserList(searchParams) | ||||
| Inherited from          WorkSpace | ||||
| Defined in          WorkSpace:135 | ||||
| userList Api call 
                        Parameters :
                        
                         
 
                        Returns :          any | 
| Private activatedRoute | 
| Type : ActivatedRoute | 
| To send activatedRoute.snapshot to router navigation service for redirection to draft component | 
| Public config | 
| Type : ConfigService | 
| To get url, app configs | 
| contentIds | 
| Type : string | 
| Contains unique contentIds id | 
| flaggedContent | 
| Type : Array<IContents> | 
| Default value : [] | 
| Contains list of published course(s) of logged-in user | 
| inviewLogs | 
| Type : [] | 
| Default value : [] | 
| inviewLogs | 
| loaderMessage | 
| Type : ILoaderMessage | 
| loader message | 
| Public navigationhelperService | 
| Type : NavigationHelperService | 
| noResult | 
| Default value : false | 
| To show / hide no result message when no result found | 
| noResultMessage | 
| Type : INoResultMessage | 
| no result message | 
| pageLimit | 
| Type : number | 
| Contains page limit of review submission list | 
| pageNumber | 
| Type : number | 
| Default value : 1 | 
| Current page number of inbox list | 
| pager | 
| Type : IPagination | 
| Contains returned object of the pagination service which is needed to show the pagination on inbox view | 
| Private paginationService | 
| Type : PaginationService | 
| For showing pagination on draft list | 
| Public resourceService | 
| Type : ResourceService | 
| To call resource service which helps to use language constant | 
| route | 
| Type : Router | 
| To navigate to other pages | 
| Public searchService | 
| Type : SearchService | 
| Inherited from          WorkSpace | 
| Defined in          WorkSpace:128 | 
| showError | 
| Default value : false | 
| To show / hide error | 
| showLoader | 
| Default value : true | 
| To show / hide loader | 
| state | 
| Type : string | 
| state for content editior | 
| telemetryImpression | 
| Type : IImpressionEventInput | 
| telemetryImpression | 
| Private toasterService | 
| Type : ToasterService | 
| To show toaster(error, success etc) after any API calls | 
| totalCount | 
| Type : Number | 
| totalCount of the list | 
| Public workSpaceService | 
| Type : WorkSpaceService | 
| Inherited from          WorkSpace | 
| Defined in          WorkSpace:129 | 
| Public userService | 
| Type : UserService | 
| Inherited from          WorkSpace | 
| Defined in          WorkSpace:26 | 
import { Component, OnInit, AfterViewInit } from '@angular/core';
import { ActivatedRoute, Router } from '@angular/router';
import { WorkSpace } from '../../classes/workspace';
import { SearchService, UserService } from '@sunbird/core';
import {
  ServerResponse, PaginationService, ToasterService,
  ResourceService, ConfigService, IContents, ILoaderMessage, INoResultMessage,
  NavigationHelperService, IPagination
} from '@sunbird/shared';
import { WorkSpaceService } from '../../services';
import * as _ from 'lodash-es';
import { IImpressionEventInput } from '@sunbird/telemetry';
/**
 * The flagged submission  component
*/
@Component({
  selector: 'app-flagged',
  templateUrl: './flagged.component.html'
})
export class FlaggedComponent extends WorkSpace implements OnInit, AfterViewInit {
  /**
  * state for content editior
 */
  state: string;
  /**
    * To navigate to other pages
  */
  route: Router;
  /**
   * To send activatedRoute.snapshot to router navigation
   * service for redirection to draft  component
  */
  private activatedRoute: ActivatedRoute;
  /**
   * Contains unique contentIds id
  */
  contentIds: string;
  /**
   * Contains list of published course(s) of logged-in user
  */
  flaggedContent: Array<IContents> = [];
  /**
   * To show / hide loader
  */
  showLoader = true;
  /**
   * loader message
  */
  loaderMessage: ILoaderMessage;
  /**
     * To show / hide error
   */
  showError = false;
  /**
    * To show / hide no result message when no result found
   */
  noResult = false;
  /**
   * no result  message
  */
  noResultMessage: INoResultMessage;
  /**
    * For showing pagination on draft list
  */
  private paginationService: PaginationService;
  /**
    * To get url, app configs
  */
  public config: ConfigService;
  /**
  * Contains page limit of review submission list
  */
  pageLimit: number;
  /**
    * Current page number of inbox list
  */
  pageNumber = 1;
  /**
  * totalCount of the list
   */
  totalCount: Number;
  /**
  * Contains returned object of the pagination service
  * which is needed to show the pagination on inbox view
  */
  pager: IPagination;
  /**
    * To call resource service which helps to use language constant
  */
  public resourceService: ResourceService;
  /**
  * To show toaster(error, success etc) after any API calls
  */
  private toasterService: ToasterService;
  /**
  * inviewLogs
  */
  inviewLogs = [];
  /**
  * telemetryImpression
  */
  telemetryImpression: IImpressionEventInput;
  /**
   * Constructor to create injected service(s) object
   Default method of Review submission  Component class
   * @param {SearchService} SearchService Reference of SearchService
   * @param {Router} route Reference of Router
   * @param {UserService} UserService Reference of UserService
   * @param {PaginationService} paginationService Reference of PaginationService
   * @param {ActivatedRoute} activatedRoute Reference of ActivatedRoute
   * @param {ConfigService} config Reference of ConfigService
   * @param {ToasterService} toaster Reference of toasterService
 */
  constructor(public searchService: SearchService,
    public workSpaceService: WorkSpaceService,
    paginationService: PaginationService,
    activatedRoute: ActivatedRoute,
    route: Router, userService: UserService,
    config: ConfigService, resourceService: ResourceService,
    toasterService: ToasterService, public navigationhelperService: NavigationHelperService) {
    super(searchService, workSpaceService, userService);
    this.paginationService = paginationService;
    this.route = route;
    this.activatedRoute = activatedRoute;
    this.config = config;
    this.resourceService = resourceService;
    this.toasterService = toasterService;
    this.loaderMessage = {
      'loaderMessage': this.resourceService.messages.stmsg.m0038,
    };
    this.state = 'flagged';
  }
  ngOnInit() {
    this.activatedRoute.params.subscribe(params => {
      this.pageNumber = Number(params.pageNumber);
      this.fetchFlaggedContents(this.config.appConfig.WORKSPACE.PAGE_LIMIT, this.pageNumber);
    });
  }
  /**
   * This method sets the make an api call to get all reviewContent with page No and offset
  */
  fetchFlaggedContents(limit: number, pageNumber: number) {
    this.showLoader = true;
    this.pageNumber = pageNumber;
    this.pageLimit = limit;
    const searchParams = {
      filters: {
        status: ['Flagged'],
        createdFor: this.userService.RoleOrgMap && this.userService.RoleOrgMap['FLAG_REVIEWER'],
        createdBy: { '!=': this.userService.userid },
        contentType: this.config.appConfig.WORKSPACE.contentType,
        objectType: this.config.appConfig.WORKSPACE.objectType,
      },
      limit: this.pageLimit,
      offset: (this.pageNumber - 1) * (this.pageLimit),
      sort_by: { lastUpdatedOn: this.config.appConfig.WORKSPACE.lastUpdatedOn }
    };
    this.search(searchParams).subscribe(
      (data: ServerResponse) => {
        if (data.result.count && data.result.content.length > 0) {
          // this.flaggedContent = data.result.content;
          this.totalCount = data.result.count;
          this.pager = this.paginationService.getPager(data.result.count, this.pageNumber, this.pageLimit);
          this.showLoader = false;
          const constantData = this.config.appConfig.WORKSPACE.Flagged.constantData;
          const metaData = this.config.appConfig.WORKSPACE.Flagged.metaData;
          const dynamicFields = this.config.appConfig.WORKSPACE.Flagged.dynamicFields;
          this.flaggedContent = this.workSpaceService.getDataForCard(data.result.content, constantData, dynamicFields, metaData);
        } else {
          this.showError = false;
          this.showLoader = false;
          this.noResult = true;
          this.noResultMessage = {
            'message': 'messages.stmsg.m0008',
            'messageText': 'messages.stmsg.m0039'
          };
        }
      },
      (err: ServerResponse) => {
        this.showLoader = false;
        this.noResult = false;
        this.showError = true;
        this.toasterService.error(this.resourceService.messages.fmsg.m0023);
      }
    );
  }
  /**
    * This method launch the content editior
  */
  contentClick(param) {
    this.workSpaceService.navigateToContent(param.data.metaData, this.state);
  }
  /**
 * This method helps to navigate to different pages.
 * If page number is less than 1 or page number is greater than total number
 * of pages is less which is not possible, then it returns.
 *
 * @param {number} page Variable to know which page has been clicked
 *
 * @example navigateToPage(1)
 */
  navigateToPage(page: number): undefined | void {
    if (page < 1 || page > this.pager.totalPages) {
      return;
    }
    this.pageNumber = page;
    this.route.navigate(['workspace/content/flagged', this.pageNumber]);
  }
  ngAfterViewInit () {
    setTimeout(() => {
      this.telemetryImpression = {
        context: {
          env: this.activatedRoute.snapshot.data.telemetry.env
        },
        edata: {
          type: this.activatedRoute.snapshot.data.telemetry.type,
          pageid: this.activatedRoute.snapshot.data.telemetry.pageid,
          uri: this.activatedRoute.snapshot.data.telemetry.uri + '/' + this.activatedRoute.snapshot.params.pageNumber,
          visits: this.inviewLogs,
          duration: this.navigationhelperService.getPageLoadTime()
        }
      };
      this.inview({ inview: [] });
    });
  }
  /**
  * get inview  Data
  */
  inview(event) {
    _.forEach(event.inview, (inview, key) => {
      const obj = _.find(this.inviewLogs, (o) => {
        return o.objid === inview.data.metaData.identifier;
      });
      if (obj === undefined) {
        this.inviewLogs.push({
          objid: inview.data.metaData.identifier,
          objtype: inview.data.metaData.contentType,
          index: inview.id
        });
      }
    });
    this.telemetryImpression.edata.visits = this.inviewLogs;
    this.telemetryImpression.edata.subtype = 'pageexit';
    this.telemetryImpression = Object.assign({}, this.telemetryImpression);
  }
}
<div class="sbt-page-gap">
  <div class="twelve wide column mt-20" *ngIf="showLoader">
    <app-loader [data]="loaderMessage"></app-loader>
  </div>
  
  <div class="ui grid my-0" *ngIf="!showLoader">
    <div class="twelve wide column" [appTelemetryImpression]="telemetryImpression">
      <div class="ui stackable three column grid" [throttle]="[1000]" [trigger]="flaggedContent">
        <div *ngFor="let content of flaggedContent;let i = index;" [id]="i" [data]="content" class="column py-5 pl-10">
          <app-card-creation [data]="content" (clickEvent)="contentClick($event)"></app-card-creation>
        </div>
      </div>
      <div *ngIf="noResult">
        <app-no-result [data]="noResultMessage"></app-no-result>
      </div>
    </div>
  </div>
  
  <div class="ui grid">
    <div class="two wide column"></div>
    <div class="ten wide column pt-0">
      <div class="pb-10" *ngIf="flaggedContent && totalCount> config.appConfig.WORKSPACE.PAGE_LIMIT && !showLoader && !showError">
        <div class="ui pagination menu mt-10 right-floated pt-0" *ngIf="pager.pages.length">
          <a [ngClass]="{disabled:pager.currentPage===1 }" class="item " tabindex="0" (click)="navigateToPage(1) ">First</a>
          <a [ngClass]="{disabled:pager.currentPage===1 }" class="item " tabindex="0" (click)="navigateToPage(pager.currentPage - 1)">Previous</a>
          <a *ngFor="let page of pager.pages" [ngClass]="{active:pager.currentPage===page}" tabindex="0" (click)="navigateToPage(page)" class="item">{{page}}</a>
          <a [ngClass]="{disabled:pager.currentPage=== pager.totalPages}" tabindex="0" (click)="navigateToPage(pager.currentPage + 1)" class="item">Next</a>
          <a [ngClass]="{disabled:pager.currentPage=== pager.totalPages}" tabindex="0" (click)="navigateToPage(pager.totalPages)" class="item ">Last</a>
        </div>
      </div>
    </div>
  </div>
</div>