internal-page-content.component.ts 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. import { HttpClient } from '@angular/common/http';
  2. import { UserService } from './../../shared/user.service';
  3. import { Router, ActivatedRoute } from '@angular/router';
  4. import { AuthServiceService } from './../../shared/auth-service.service';
  5. import { Component, OnInit, AfterViewInit, ViewChild, EventEmitter } from '@angular/core';
  6. import { InternalPageService } from '../../shared/internal-page.service';
  7. import { NgxSpinnerService } from 'ngx-spinner';
  8. import {NgbCarousel,NgbCarouselConfig} from '@ng-bootstrap/ng-bootstrap';
  9. import * as $ from 'jquery';
  10. declare var jQuery: any;
  11. @Component({
  12. selector: 'app-internal-page-content',
  13. templateUrl: './internal-page-content.component.html',
  14. styleUrls: ['./internal-page-content.component.css'],
  15. providers: [NgbCarouselConfig],
  16. })
  17. export class InternalPageContentComponent implements OnInit {
  18. @ViewChild('myCarousel') myCarousel: NgbCarousel;
  19. constructor(private authSer: AuthServiceService,
  20. private router:Router,
  21. private userservice: UserService,
  22. private internalService: InternalPageService,
  23. private route: ActivatedRoute,
  24. private config: NgbCarouselConfig,
  25. private http: HttpClient,
  26. private spinner: NgxSpinnerService) {
  27. this.spinner.show();
  28. }
  29. joinUs = [];
  30. reportsData = [];
  31. externalServices = [];
  32. congratulations = [];
  33. condolences = [];
  34. internalServices = [];
  35. tabsData = [];
  36. achievements = [];
  37. tabCongaData= {
  38. employee_name: '',
  39. employee_name_en: '',
  40. created_at: '',
  41. name: '',
  42. name_en: '',
  43. };
  44. tabSadData = {
  45. employee_name: '',
  46. employee_name_en: '',
  47. created_at: '',
  48. name: '',
  49. name_en: ''
  50. };
  51. joinTabData = {
  52. name: '',
  53. name_en: '',
  54. adminstration_name: '',
  55. adminstration_name_en: '',
  56. date_of_employment_hij: '',
  57. photo: '',
  58. };
  59. advertisiment = {
  60. photo : '',
  61. description: '',
  62. description_en: '',
  63. };
  64. checkShowData: boolean;
  65. tabtype:number = 0;
  66. expandedIndex:number;
  67. selectedItem: any = 0 //check تعاميم active class
  68. live_event = [];
  69. next_lecture = [];
  70. myInnerHeight = window.innerHeight;
  71. flag: boolean = false;
  72. catchEvent(event) {
  73. this.flag = true
  74. console.log(event)
  75. }
  76. hide(event) {
  77. this.flag = false;
  78. }
  79. ngOnInit() {
  80. //console.log(this.checkTokenExpire);
  81. //get profile data
  82. //this.userservice.getUserDataProfile();
  83. this.authSer.homeStyle = true;
  84. this.internalService.getParentData().subscribe(
  85. (responce) => {
  86. this.authSer.parentsPage = responce['parents'];
  87. for(let i = 0; i < this.authSer.parentsPage.length; i++) {
  88. this.authSer.parentsPage[i].active = 0;
  89. }
  90. this.spinner.hide();
  91. },
  92. (error) => {
  93. console.log(error);
  94. }
  95. );
  96. this.internalService.getInternalPageData().subscribe(
  97. (responce) => {
  98. console.log(responce);
  99. this.externalServices = responce['data'].external_services;
  100. console.log('external services ', this.externalServices);
  101. this.reportsData = responce['data'].reports;
  102. console.log('report data', this.reportsData);
  103. for(let i = 0; i< this.reportsData.length; i++) {
  104. if(this.reportsData[i].description.length > 60) {
  105. this.reportsData[i].description = this.reportsData[i].description.substr(0,100) + '.......';
  106. this.reportsData[i].description_en = this.reportsData[i].description_en.substr(0,100) + 'Read More';
  107. }
  108. }
  109. this.live_event = responce['data'].live_lecture;
  110. this.next_lecture = responce['data'].next_lecture;
  111. this.joinUs = responce['data'].users;
  112. this.showJoinData(this.joinUs[0]);
  113. this.condolences = responce['data'].condolences_events;
  114. this.showTabData(this.condolences[0], 'sad');
  115. this.congratulations = responce['data'].congratulations_events;
  116. this.showTabData(this.congratulations[0], 'wedding');
  117. this.internalService = responce['data'].internal_services;
  118. console.log('internalService', this.internalService);
  119. this.tabsData = responce['data'].tabs;
  120. if(this.tabsData.length > 0) {
  121. this.checkShowData = false;
  122. } else {
  123. this.checkShowData = true;
  124. }
  125. this.achievements = responce['data'].achievements;
  126. this.advertisiment = {
  127. photo: responce['data']['main_ad'].photo,
  128. description: responce['data']['main_ad'].description,
  129. description_en: responce['data']['main_ad'].description_en,
  130. }
  131. this.spinner.hide();
  132. },
  133. (error) => {
  134. console.log(error);
  135. }
  136. )
  137. }
  138. onGetData(numberTab) {
  139. this.selectedItem = numberTab;
  140. this.spinner.show();
  141. this.tabsData = [];
  142. this.tabtype = numberTab;
  143. this.http.get(this.authSer.pathApi + '/forth_tabs_list/' + this.tabtype).subscribe(
  144. (responce) => {
  145. console.log(responce);
  146. this.tabsData = responce['tabs'];
  147. this.spinner.hide();
  148. },
  149. (error) => {
  150. console.log(error);
  151. }
  152. );
  153. }
  154. onExtraPage(reportId) {
  155. this.router.navigate(['InternalPage/news/' + reportId]);
  156. }
  157. open(data,i) {
  158. console.log(data);
  159. this.expandedIndex = i;
  160. }
  161. closeCollapse(i) {
  162. this.expandedIndex = -1;
  163. }
  164. goToHome() {
  165. this.router.navigate(['InternalPage']);
  166. }
  167. onPageCir() {
  168. this.router.navigate(['InternalPage/circulars']);
  169. }
  170. onLectureTable() {
  171. this.router.navigate(['InternalPage/events']);
  172. }
  173. showTabData(tab, typeTab) {
  174. console.log(tab);
  175. if(typeTab == 'wedding') {
  176. this.tabCongaData = {
  177. employee_name : tab.employee_name,
  178. employee_name_en: tab.employee_name_en,
  179. created_at: tab.created_at,
  180. name: tab.name,
  181. name_en: tab.name_en,
  182. };
  183. for(let i = 0 ; i < this.congratulations.length; i++) {
  184. if(this.congratulations[i].id == tab.id) {
  185. this.congratulations[i].active = 1;
  186. } else {
  187. this.congratulations[i].active = 0;
  188. }
  189. }
  190. } else if(typeTab == 'sad') {
  191. this.tabSadData = {
  192. employee_name : tab.employee_name,
  193. employee_name_en: tab.employee_name_en,
  194. created_at: tab.created_at,
  195. name: tab.name,
  196. name_en: tab.name_en
  197. };
  198. for(let i = 0 ; i < this.condolences.length; i++) {
  199. if(this.condolences[i].id == tab.id) {
  200. this.condolences[i].active = 1;
  201. } else {
  202. this.condolences[i].active = 0;
  203. }
  204. }
  205. }
  206. }
  207. showJoinData(join){
  208. this.joinTabData = {
  209. name : join.name,
  210. name_en: join.name_en,
  211. adminstration_name: join.adminstration_name,
  212. adminstration_name_en: join.adminstration_name,
  213. date_of_employment_hij: join.date_of_employment_hij,
  214. photo: join.photo,
  215. };
  216. for(let i = 0 ; i < this.joinUs.length; i++) {
  217. if(this.joinUs[i].id == join.id) {
  218. this.joinUs[i].active = 1;
  219. } else {
  220. this.joinUs[i].active = 0;
  221. }
  222. }
  223. }
  224. getAllNews() {
  225. this.router.navigate(['InternalPage/newpages/']);
  226. }
  227. }