@thecodeblogs/blog 0.15.4 → 0.15.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -14,6 +14,7 @@ import * as i5 from "@angular/forms";
14
14
  import * as i6 from "@angular/material/input";
15
15
  import * as i7 from "@angular/material/form-field";
16
16
  import * as i8 from "@angular/material/list";
17
+ import * as i9 from "@angular/material/progress-spinner";
17
18
  export class SideNavigationComponent {
18
19
  constructor(entryService, router, identityService, renderer) {
19
20
  this.entryService = entryService;
@@ -21,6 +22,9 @@ export class SideNavigationComponent {
21
22
  this.identityService = identityService;
22
23
  this.renderer = renderer;
23
24
  this.state = 'out';
25
+ this.response = null;
26
+ this.debounceTimeout = 200;
27
+ this.loading = true;
24
28
  this.entries = [];
25
29
  this.entriesByMonthAndYear = [];
26
30
  this.searchTerm = "";
@@ -28,7 +32,7 @@ export class SideNavigationComponent {
28
32
  this.searchControl = new FormControl('');
29
33
  }
30
34
  ngOnInit() {
31
- this.doSearch.pipe(debounceTime(500)).subscribe((result) => {
35
+ this.doSearch.pipe(debounceTime(this.debounceTimeout)).subscribe((result) => {
32
36
  this.searchEntries(result);
33
37
  });
34
38
  this.identityService.getMe().subscribe((identity) => {
@@ -38,23 +42,27 @@ export class SideNavigationComponent {
38
42
  });
39
43
  this.getEntries();
40
44
  }
41
- getEntriesWithUrl(url) {
45
+ getMore() {
46
+ this.getEntriesWithUrl(this.response.next, false);
47
+ }
48
+ getEntriesWithUrl(url, wipe = true) {
49
+ this.loading = true;
42
50
  this.entryService.getListByUrl(url).subscribe((response) => {
51
+ this.response = response;
43
52
  this.entries = this.entries.concat(map(response.results, (result) => {
44
53
  return { id: result.id, entry: new Entry(result) };
45
54
  }));
46
- if (response.next) {
47
- this.getEntriesWithUrl(response.next);
48
- }
49
- else {
50
- this.organizeEntries();
51
- }
55
+ this.organizeEntries(wipe);
52
56
  });
53
57
  }
54
- organizeEntries() {
55
- this.state = 'out';
58
+ organizeEntries(wipe = true) {
59
+ if (wipe) {
60
+ this.state = 'out';
61
+ }
56
62
  let organizeEntriesFn = () => {
57
- this.entriesByMonthAndYear = [];
63
+ if (wipe) {
64
+ this.entriesByMonthAndYear = [];
65
+ }
58
66
  let newEntries = JSON.parse(JSON.stringify(this.entriesByMonthAndYear));
59
67
  for (const entryWrapper of this.entries) {
60
68
  const entry = entryWrapper.entry;
@@ -82,37 +90,37 @@ export class SideNavigationComponent {
82
90
  newEntries.reverse();
83
91
  let setEntriesFn = () => {
84
92
  this.entriesByMonthAndYear = newEntries;
85
- this.state = 'in';
93
+ this.loading = false;
94
+ if (wipe) {
95
+ this.state = 'in';
96
+ }
86
97
  };
87
98
  setTimeout(setEntriesFn.bind(this), 400);
88
99
  };
89
100
  setTimeout(organizeEntriesFn.bind(this), 400);
90
101
  }
91
102
  getEntries() {
103
+ this.loading = true;
92
104
  this.entryService.get().subscribe((response) => {
105
+ this.response = response;
93
106
  this.entries = map(response.results, (result) => {
94
107
  return { id: result.id, entry: new Entry(result) };
95
108
  });
96
- if (response.next) {
97
- this.getEntriesWithUrl(response.next);
98
- }
99
- else {
100
- this.organizeEntries();
101
- }
109
+ this.organizeEntries();
102
110
  });
103
111
  }
104
112
  searchEntries(searchTerm) {
113
+ let turnOnLoading = () => {
114
+ this.loading = true;
115
+ };
116
+ setTimeout(turnOnLoading.bind(this), this.debounceTimeout + 100);
105
117
  if (searchTerm !== "") {
106
118
  this.entryService.search(searchTerm).subscribe((response) => {
119
+ this.response = response;
107
120
  this.entries = map(response.results, (result) => {
108
121
  return { id: result.id, entry: new Entry(result) };
109
122
  });
110
- if (response.next) {
111
- this.getEntriesWithUrl(response.next);
112
- }
113
- else {
114
- this.organizeEntries();
115
- }
123
+ this.organizeEntries();
116
124
  });
117
125
  }
118
126
  else {
@@ -189,7 +197,7 @@ export class SideNavigationComponent {
189
197
  }
190
198
  }
191
199
  SideNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SideNavigationComponent, deps: [{ token: i1.EntryService }, { token: i2.Router }, { token: i3.IdentityService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
192
- SideNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SideNavigationComponent, selector: "app-side-navigation", viewQueries: [{ propertyName: "divNav", first: true, predicate: ["navcontainer"], descendants: true }], ngImport: i0, template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n </div>\n\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".sidenav{max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "component", type: i8.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i8.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }], animations: [
200
+ SideNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SideNavigationComponent, selector: "app-side-navigation", viewQueries: [{ propertyName: "divNav", first: true, predicate: ["navcontainer"], descendants: true }], ngImport: i0, template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div\n class=\"progress\"\n [hidden]=\"!loading\"\n >\n <mat-progress-spinner\n style=\"margin-left: 16px;\"\n [diameter]=20\n mode=\"indeterminate\"\n >\n </mat-progress-spinner>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n <a\n class=\"sidelink\"\n *ngIf=\"this?.response?.next && !loading\"\n (click)=\"getMore()\"\n href=\"javascript:void(0);\">More...</a>\n </div>\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".progress{position:absolute;top:100px;left:0}.sidelink{padding-left:16px}.sidenav{position:relative;max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "component", type: i8.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i8.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "component", type: i9.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }], animations: [
193
201
  trigger('sideNavAnimation', [
194
202
  state('in', style({ transform: 'translateX(0%)' })),
195
203
  state('out', style({ transform: 'translateX(110%)' })),
@@ -214,9 +222,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
214
222
  animate('100ms ease-in', style({ transform: 'translateX(0%)' }))
215
223
  ])
216
224
  ]),
217
- ], template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n </div>\n\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".sidenav{max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"] }]
225
+ ], template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div\n class=\"progress\"\n [hidden]=\"!loading\"\n >\n <mat-progress-spinner\n style=\"margin-left: 16px;\"\n [diameter]=20\n mode=\"indeterminate\"\n >\n </mat-progress-spinner>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n <a\n class=\"sidelink\"\n *ngIf=\"this?.response?.next && !loading\"\n (click)=\"getMore()\"\n href=\"javascript:void(0);\">More...</a>\n </div>\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".progress{position:absolute;top:100px;left:0}.sidelink{padding-left:16px}.sidenav{position:relative;max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"] }]
218
226
  }], ctorParameters: function () { return [{ type: i1.EntryService }, { type: i2.Router }, { type: i3.IdentityService }, { type: i0.Renderer2 }]; }, propDecorators: { divNav: [{
219
227
  type: ViewChild,
220
228
  args: ['navcontainer', { static: false }]
221
229
  }] } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-navigation.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/components/side-navigation/side-navigation.component.ts","../../../../../../projects/core/src/lib/components/side-navigation/side-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, OnDestroy, OnInit, Output, ElementRef, ViewChild, Renderer2} from '@angular/core';\nimport { trigger, state, style, animate, transition } from '@angular/animations';\nimport {Router} from '@angular/router';\nimport { FormControl } from '@angular/forms';\nimport {filter} from 'lodash';\nimport {map} from 'lodash';\nimport {debounceTime} from 'rxjs/operators';\n\nimport {Entry} from '../../data/entry';\nimport {Identity} from '../../data/identity';\n\nimport {EntryService} from '../../services/entry.service';\nimport {IdentityService} from '../../services/identity.service';\n\n@Component({\n  selector: 'app-side-navigation',\n  templateUrl: './side-navigation.component.html',\n  styleUrls: ['./side-navigation.component.scss'],\n  animations: [\n    trigger('sideNavAnimation', [\n      state('in', style({transform: 'translateX(0%)'})),\n      state('out', style({transform: 'translateX(110%)'})),\n      transition('in => out', [\n        animate('100ms ease-out', style({transform: 'translateX(110%)'}))\n      ]),\n      transition('out => in', [\n        animate('100ms ease-in', style({transform: 'translateX(0%)'}))\n      ])\n    ]),\n  ]\n})\nexport class SideNavigationComponent implements OnInit, OnDestroy {\n\n  state: 'in' | 'out' = 'out';\n\n  sourceSub;\n  identity: Identity;\n\n  entries: {id: string, entry: Entry}[] = [];\n  entriesByMonthAndYear: {month_year: string, month_year_number: number, entries: Entry[]}[] = [];\n\n  searchTerm = \"\";\n\n  doSearch: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('navcontainer', { static: false }) divNav: ElementRef;\n\n  constructor(\n    private entryService: EntryService,\n    private router: Router,\n    private identityService: IdentityService,\n    private renderer: Renderer2,\n  ) {\n  }\n\n  ngOnInit() {\n\n    this.doSearch.pipe(debounceTime(500)).subscribe((result) => {\n      this.searchEntries(result);\n    });\n\n    this.identityService.getMe().subscribe((identity) => {\n      this.identity = identity;\n    }, (err) => {\n        this.identity = null;\n      });\n\n    this.getEntries();\n\n  }\n\n  getEntriesWithUrl(url: string) {\n    this.entryService.getListByUrl(url).subscribe((response) => {\n      this.entries = this.entries.concat(\n        map((response as any).results, (result) => {\n          return { id: result.id, entry: new Entry(result)};\n        })\n      );\n      if ((response as any).next) {\n        this.getEntriesWithUrl(response.next);\n      } else {\n        this.organizeEntries();\n      }\n    });\n  }\n\n  organizeEntries() {\n    this.state = 'out';\n    let organizeEntriesFn = () => {\n      this.entriesByMonthAndYear = [];\n      let newEntries = JSON.parse(JSON.stringify(this.entriesByMonthAndYear));\n      for (const entryWrapper of this.entries) {\n        const entry = entryWrapper.entry;\n        const create_date = new Date(entry.create_date);\n        const month = create_date.getMonth();\n        const year = create_date.getFullYear();\n        const key = month + '/' + year;\n        const sort_index = (year * 100) + month;\n        const containers = filter(newEntries, (entryContainer) => entryContainer.month_year === key);\n        if (containers.length > 0) {\n          const container = containers[0];\n          const entriesWithId = filter(container.entries, (e) => e.id === entryWrapper.entry.id);\n          if (entriesWithId.length === 0) {\n            container.entries.push(entry);\n          }\n        } else {\n          const newContainer = {month_year: key, month_year_number: sort_index, entries: [entry]};\n          newEntries.push(newContainer);\n        }\n      }\n      newEntries.sort(\n        (entry_a, entry_b) => {\n          return entry_a.month_year_number - entry_b.month_year_number;\n        });\n      newEntries.reverse();\n\n      let setEntriesFn = () => {\n        this.entriesByMonthAndYear = newEntries;\n        this.state = 'in';\n      }\n      setTimeout(setEntriesFn.bind(this), 400)\n    }\n    setTimeout(organizeEntriesFn.bind(this), 400)\n  }\n\n  getEntries() {\n    this.entryService.get().subscribe((response) => {\n      this.entries = map(response.results, (result) => {\n        return { id: result.id, entry: new Entry(result)};\n      });\n      if ((response as any).next) {\n        this.getEntriesWithUrl(response.next);\n      } else {\n        this.organizeEntries();\n      }\n    });\n  }\n\n  searchEntries(searchTerm: string) {\n    if (searchTerm !== \"\") {\n      this.entryService.search(searchTerm).subscribe((response) => {\n        this.entries = map(response.results, (result) => {\n          return { id: result.id, entry: new Entry(result)};\n        });\n        if ((response as any).next) {\n          this.getEntriesWithUrl(response.next);\n        } else {\n          this.organizeEntries();\n        }\n      });\n    } else {\n      this.getEntries();\n    }\n  }\n\n  render() {\n  }\n\n  routeTo(entry) {\n    if (!entry) {\n      this.router.navigateByUrl('create(left-col:create//right-col:create)').then(() => {\n\n      });\n    } else {\n      this.router.navigate(['/', 'blog', entry.slug]).then(() => {\n        // Noop\n      });\n    }\n  }\n\n  getMonthAndYearFromKey(key: string) {\n    let subheading = '';\n    const parts = key.split('/');\n\n    switch (Number(parts[0])) {\n      case 0:\n        subheading += 'January ';\n        break;\n      case 1:\n        subheading += 'February ';\n        break;\n      case 2:\n        subheading += 'March ';\n        break;\n      case 3:\n        subheading += 'April ';\n        break;\n      case 4:\n        subheading += 'May ';\n        break;\n      case 5:\n        subheading += 'June ';\n        break;\n      case 6:\n        subheading += 'July ';\n        break;\n      case 7:\n        subheading += 'August ';\n        break;\n      case 8:\n        subheading += 'September ';\n        break;\n      case 9:\n        subheading += 'October ';\n        break;\n      case 10:\n        subheading += 'November ';\n        break;\n      case 11:\n        subheading += 'December ';\n        break;\n      default:\n        subheading += 'January ';\n    }\n    subheading += parts[1];\n\n    return subheading;\n  }\n\n  ngOnDestroy(): void {\n    if (this.sourceSub) {\n      this.sourceSub.unsubscribe();\n      this.sourceSub = null;\n    }\n  }\n\n  searchControl = new FormControl('');\n\n  onSearchChange(searchValue: string): void {\n    this.doSearch.emit(searchValue);\n  }\n}\n","<div class=\"sidenav no-scrollbar\">\n  <div style=\"margin-top: 20px;\">\n    <mat-form-field style=\"width: 100%\">\n      <mat-label>Search</mat-label>\n      <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n    </mat-form-field>\n  </div>\n\n  <div #navcontainer class=\"navcontainer\"\n    [@sideNavAnimation]=\"state\"\n  >\n    <mat-nav-list\n      *ngFor=\"let container of entriesByMonthAndYear\"\n    >\n      <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n      <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n    </mat-nav-list>\n\n  </div>\n\n  <ng-container *ngIf=\"identity?.id === 1\">\n    <h2>Misc</h2>\n\n    <mat-nav-list>\n      <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n    </mat-nav-list>\n  </ng-container>\n  <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n"]}
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-navigation.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/components/side-navigation/side-navigation.component.ts","../../../../../../projects/core/src/lib/components/side-navigation/side-navigation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, OnDestroy, OnInit, Output, ElementRef, ViewChild, Renderer2} from '@angular/core';\nimport { trigger, state, style, animate, transition } from '@angular/animations';\nimport {Router} from '@angular/router';\nimport { FormControl } from '@angular/forms';\nimport {filter} from 'lodash';\nimport {map} from 'lodash';\nimport {debounceTime} from 'rxjs/operators';\n\nimport {Entry} from '../../data/entry';\nimport {Identity} from '../../data/identity';\nimport {ListResponse} from '../../data/list-response';\n\nimport {EntryService} from '../../services/entry.service';\nimport {IdentityService} from '../../services/identity.service';\n\n@Component({\n  selector: 'app-side-navigation',\n  templateUrl: './side-navigation.component.html',\n  styleUrls: ['./side-navigation.component.scss'],\n  animations: [\n    trigger('sideNavAnimation', [\n      state('in', style({transform: 'translateX(0%)'})),\n      state('out', style({transform: 'translateX(110%)'})),\n      transition('in => out', [\n        animate('100ms ease-out', style({transform: 'translateX(110%)'}))\n      ]),\n      transition('out => in', [\n        animate('100ms ease-in', style({transform: 'translateX(0%)'}))\n      ])\n    ]),\n  ]\n})\nexport class SideNavigationComponent implements OnInit, OnDestroy {\n\n  state: 'in' | 'out' = 'out';\n\n  sourceSub;\n  identity: Identity;\n\n  response: ListResponse<Entry> = null;\n  debounceTimeout = 200;\n  loading = true;\n\n  entries: {id: string, entry: Entry}[] = [];\n  entriesByMonthAndYear: {month_year: string, month_year_number: number, entries: Entry[]}[] = [];\n\n  searchTerm = \"\";\n\n  doSearch: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('navcontainer', { static: false }) divNav: ElementRef;\n\n  constructor(\n    private entryService: EntryService,\n    private router: Router,\n    private identityService: IdentityService,\n    private renderer: Renderer2,\n  ) {\n  }\n\n  ngOnInit() {\n\n    this.doSearch.pipe(debounceTime(this.debounceTimeout)).subscribe((result) => {\n      this.searchEntries(result);\n    });\n\n    this.identityService.getMe().subscribe((identity) => {\n      this.identity = identity;\n    }, (err) => {\n        this.identity = null;\n      });\n\n    this.getEntries();\n\n  }\n\n  getMore() {\n    this.getEntriesWithUrl(this.response.next, false);\n  }\n\n  getEntriesWithUrl(url: string, wipe = true) {\n    this.loading = true;\n    this.entryService.getListByUrl(url).subscribe((response) => {\n      this.response = response;\n      this.entries = this.entries.concat(\n        map((response as any).results, (result) => {\n          return { id: result.id, entry: new Entry(result)};\n        })\n      );\n      this.organizeEntries(wipe);\n    });\n  }\n\n  organizeEntries(wipe = true) {\n    if (wipe) {\n      this.state = 'out';\n    }\n    let organizeEntriesFn = () => {\n      if(wipe) {\n        this.entriesByMonthAndYear = [];\n      }\n      let newEntries = JSON.parse(JSON.stringify(this.entriesByMonthAndYear));\n      for (const entryWrapper of this.entries) {\n        const entry = entryWrapper.entry;\n        const create_date = new Date(entry.create_date);\n        const month = create_date.getMonth();\n        const year = create_date.getFullYear();\n        const key = month + '/' + year;\n        const sort_index = (year * 100) + month;\n        const containers = filter(newEntries, (entryContainer) => entryContainer.month_year === key);\n        if (containers.length > 0) {\n          const container = containers[0];\n          const entriesWithId = filter(container.entries, (e) => e.id === entryWrapper.entry.id);\n          if (entriesWithId.length === 0) {\n            container.entries.push(entry);\n          }\n        } else {\n          const newContainer = {month_year: key, month_year_number: sort_index, entries: [entry]};\n          newEntries.push(newContainer);\n        }\n      }\n      newEntries.sort(\n        (entry_a, entry_b) => {\n          return entry_a.month_year_number - entry_b.month_year_number;\n        });\n      newEntries.reverse();\n\n      let setEntriesFn = () => {\n        this.entriesByMonthAndYear = newEntries;\n        this.loading = false;\n        if (wipe) {\n          this.state = 'in';\n        }\n      }\n      setTimeout(setEntriesFn.bind(this), 400)\n    }\n    setTimeout(organizeEntriesFn.bind(this), 400)\n  }\n\n  getEntries() {\n    this.loading = true;\n    this.entryService.get().subscribe((response) => {\n      this.response = response;\n      this.entries = map(response.results, (result) => {\n        return { id: result.id, entry: new Entry(result)};\n      });\n      this.organizeEntries();\n    });\n  }\n\n  searchEntries(searchTerm: string) {\n\n    let turnOnLoading = () => {\n      this.loading = true;\n    }\n    setTimeout(turnOnLoading.bind(this), this.debounceTimeout + 100);\n    if (searchTerm !== \"\") {\n      this.entryService.search(searchTerm).subscribe((response) => {\n        this.response = response;\n        this.entries = map(response.results, (result) => {\n          return { id: result.id, entry: new Entry(result)};\n        });\n        this.organizeEntries();\n      });\n    } else {\n      this.getEntries();\n    }\n  }\n\n  render() {\n  }\n\n  routeTo(entry) {\n    if (!entry) {\n      this.router.navigateByUrl('create(left-col:create//right-col:create)').then(() => {\n\n      });\n    } else {\n      this.router.navigate(['/', 'blog', entry.slug]).then(() => {\n        // Noop\n      });\n    }\n  }\n\n  getMonthAndYearFromKey(key: string) {\n    let subheading = '';\n    const parts = key.split('/');\n\n    switch (Number(parts[0])) {\n      case 0:\n        subheading += 'January ';\n        break;\n      case 1:\n        subheading += 'February ';\n        break;\n      case 2:\n        subheading += 'March ';\n        break;\n      case 3:\n        subheading += 'April ';\n        break;\n      case 4:\n        subheading += 'May ';\n        break;\n      case 5:\n        subheading += 'June ';\n        break;\n      case 6:\n        subheading += 'July ';\n        break;\n      case 7:\n        subheading += 'August ';\n        break;\n      case 8:\n        subheading += 'September ';\n        break;\n      case 9:\n        subheading += 'October ';\n        break;\n      case 10:\n        subheading += 'November ';\n        break;\n      case 11:\n        subheading += 'December ';\n        break;\n      default:\n        subheading += 'January ';\n    }\n    subheading += parts[1];\n\n    return subheading;\n  }\n\n  ngOnDestroy(): void {\n    if (this.sourceSub) {\n      this.sourceSub.unsubscribe();\n      this.sourceSub = null;\n    }\n  }\n\n  searchControl = new FormControl('');\n\n  onSearchChange(searchValue: string): void {\n    this.doSearch.emit(searchValue);\n  }\n}\n","<div class=\"sidenav no-scrollbar\">\n  <div style=\"margin-top: 20px;\">\n    <mat-form-field style=\"width: 100%\">\n      <mat-label>Search</mat-label>\n      <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n    </mat-form-field>\n  </div>\n\n  <div\n    class=\"progress\"\n    [hidden]=\"!loading\"\n  >\n    <mat-progress-spinner\n      style=\"margin-left: 16px;\"\n      [diameter]=20\n      mode=\"indeterminate\"\n    >\n    </mat-progress-spinner>\n  </div>\n\n  <div #navcontainer class=\"navcontainer\"\n    [@sideNavAnimation]=\"state\"\n  >\n    <mat-nav-list\n      *ngFor=\"let container of entriesByMonthAndYear\"\n    >\n      <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n      <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n    </mat-nav-list>\n\n    <a\n      class=\"sidelink\"\n      *ngIf=\"this?.response?.next && !loading\"\n      (click)=\"getMore()\"\n      href=\"javascript:void(0);\">More...</a>\n  </div>\n  <ng-container *ngIf=\"identity?.id === 1\">\n    <h2>Misc</h2>\n\n    <mat-nav-list>\n      <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n    </mat-nav-list>\n  </ng-container>\n  <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n"]}
@@ -17,6 +17,7 @@ import { MatIconModule } from '@angular/material/icon';
17
17
  import { MatNativeDateModule } from '@angular/material/core';
18
18
  import { MatDatepickerModule } from '@angular/material/datepicker';
19
19
  import { MatTableModule } from '@angular/material/table';
20
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
20
21
  import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
21
22
  import { faSpinner } from '@fortawesome/free-solid-svg-icons';
22
23
  import { FileUploadModule } from 'ng2-file-upload';
@@ -87,6 +88,7 @@ CoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15
87
88
  MatDatepickerModule,
88
89
  MatNativeDateModule,
89
90
  MatTableModule,
91
+ MatProgressSpinnerModule,
90
92
  FontAwesomeModule,
91
93
  FileUploadModule,
92
94
  NgxMaterialTimepickerModule], exports: [EntryRendererComponent,
@@ -131,6 +133,7 @@ CoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15
131
133
  MatDatepickerModule,
132
134
  MatNativeDateModule,
133
135
  MatTableModule,
136
+ MatProgressSpinnerModule,
134
137
  FontAwesomeModule,
135
138
  FileUploadModule,
136
139
  NgxMaterialTimepickerModule] });
@@ -175,6 +178,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
175
178
  MatDatepickerModule,
176
179
  MatNativeDateModule,
177
180
  MatTableModule,
181
+ MatProgressSpinnerModule,
178
182
  FontAwesomeModule,
179
183
  FileUploadModule,
180
184
  NgxMaterialTimepickerModule,
@@ -206,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
206
210
  ]
207
211
  }]
208
212
  }], ctorParameters: function () { return [{ type: i1.FaIconLibrary }]; } });
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.module.js","sourceRoot":"","sources":["../../../../projects/core/src/lib/core.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {BrowserModule} from '@angular/platform-browser';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\n\nimport {DragDropModule} from '@angular/cdk/drag-drop';\nimport {MatDividerModule} from '@angular/material/divider';\nimport {MatCardModule} from '@angular/material/card';\nimport {MatSidenavModule} from '@angular/material/sidenav';\nimport {MatButtonModule} from '@angular/material/button';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatListModule} from '@angular/material/list';\nimport {MatRadioModule} from '@angular/material/radio';\nimport {MatDialogModule} from '@angular/material/dialog';\nimport {MatCheckboxModule} from '@angular/material/checkbox';\nimport {MatAutocompleteModule} from '@angular/material/autocomplete';\nimport {MatChipsModule} from '@angular/material/chips';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatNativeDateModule} from '@angular/material/core';\nimport {MatDatepickerModule} from '@angular/material/datepicker';\nimport {MatTableModule} from '@angular/material/table';\n\nimport {FontAwesomeModule, FaIconLibrary} from '@fortawesome/angular-fontawesome';\nimport {faSpinner} from '@fortawesome/free-solid-svg-icons';\nimport {FileUploadModule} from 'ng2-file-upload';\nimport {NgxMaterialTimepickerModule} from 'ngx-material-timepicker';\n\nimport { CommentService } from './services/comment.service';\nimport { EntryService } from './services/entry.service';\nimport { UploadService } from './services/upload.service';\nimport { PrismService } from './services/prism.service';\nimport { IdentityService } from './services/identity.service';\nimport { DjangoRestFrameworkEndpointService } from './services/django-rest-framework-endpoint.service';\nimport {EntryRendererComponent} from './components/entry-renderer/entry-renderer.component';\nimport {EntryCreatorComponent} from './components/entry-creator/entry-creator.component';\nimport {OutlineViewComponent} from './components/outline-view/outline-view.component';\nimport {SideNavigationComponent} from './components/side-navigation/side-navigation.component';\nimport {LandingPageComponent} from './components/landing-page/landing-page.component';\nimport {JsonRendererComponent} from './components/json-renderer/json-renderer.component';\nimport {EntrySummaryComponent} from './components/entry-summary/entry-summary.component';\nimport { MediaUploadModalComponent } from './components/media-upload-modal/media-upload-modal.component';\nimport { EntrySelectorDialogComponent } from './components/entry-selector-dialog/entry-selector-dialog.component';\nimport {TimeAgoPipe} from './pipes/TimeAgoPipe';\nimport {LinkyPipe} from './pipes/LinkyPipe';\nimport { StaticHtmlComponent } from './components/static-html/static-html.component';\nimport {TagService} from './services/tag.service';\nimport { MainComponent } from './components/main/main.component';\nimport { EntryRendererWrapperComponent } from './components/entry-renderer-wrapper/entry-renderer-wrapper.component';\nimport {RouterModule} from '@angular/router';\nimport { SchedulePublishDialogComponent } from './components/schedule-publish-dialog/schedule-publish-dialog.component';\n\n\n@NgModule({\n    declarations: [\n        EntryRendererComponent,\n        EntryCreatorComponent,\n        LandingPageComponent,\n        SideNavigationComponent,\n        OutlineViewComponent,\n        JsonRendererComponent,\n        EntrySummaryComponent,\n        EntrySelectorDialogComponent,\n        MediaUploadModalComponent,\n        TimeAgoPipe,\n        LinkyPipe,\n        StaticHtmlComponent,\n        MainComponent,\n        EntryRendererWrapperComponent,\n        SchedulePublishDialogComponent,\n    ],\n    imports: [\n        CommonModule,\n        RouterModule,\n        FormsModule,\n        ReactiveFormsModule,\n        DragDropModule,\n        MatCardModule,\n        MatSidenavModule,\n        MatButtonModule,\n        MatInputModule,\n        MatListModule,\n        MatRadioModule,\n        MatDialogModule,\n        MatCheckboxModule,\n        MatDividerModule,\n        MatAutocompleteModule,\n        MatChipsModule,\n        MatIconModule,\n        MatDatepickerModule,\n        MatNativeDateModule,\n        MatTableModule,\n        FontAwesomeModule,\n        FileUploadModule,\n        NgxMaterialTimepickerModule,\n    ],\n    providers: [\n        CommentService,\n        EntryService,\n        UploadService,\n        PrismService,\n        IdentityService,\n        DjangoRestFrameworkEndpointService,\n        TagService,\n    ],\n    exports: [\n        EntryRendererComponent,\n        EntryCreatorComponent,\n        LandingPageComponent,\n        SideNavigationComponent,\n        OutlineViewComponent,\n        JsonRendererComponent,\n        EntrySummaryComponent,\n        EntrySelectorDialogComponent,\n        MediaUploadModalComponent,\n        TimeAgoPipe,\n        LinkyPipe,\n        StaticHtmlComponent,\n        MainComponent,\n        EntryRendererWrapperComponent,\n    ]\n})\nexport class CoreModule {\n    constructor(\n        private library: FaIconLibrary\n    ) {\n        this.library.addIcons(faSpinner);\n    }\n}\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.module.js","sourceRoot":"","sources":["../../../../projects/core/src/lib/core.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {BrowserModule} from '@angular/platform-browser';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\n\nimport {DragDropModule} from '@angular/cdk/drag-drop';\nimport {MatDividerModule} from '@angular/material/divider';\nimport {MatCardModule} from '@angular/material/card';\nimport {MatSidenavModule} from '@angular/material/sidenav';\nimport {MatButtonModule} from '@angular/material/button';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatListModule} from '@angular/material/list';\nimport {MatRadioModule} from '@angular/material/radio';\nimport {MatDialogModule} from '@angular/material/dialog';\nimport {MatCheckboxModule} from '@angular/material/checkbox';\nimport {MatAutocompleteModule} from '@angular/material/autocomplete';\nimport {MatChipsModule} from '@angular/material/chips';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatNativeDateModule} from '@angular/material/core';\nimport {MatDatepickerModule} from '@angular/material/datepicker';\nimport {MatTableModule} from '@angular/material/table';\nimport {MatProgressSpinnerModule} from '@angular/material/progress-spinner';\n\nimport {FontAwesomeModule, FaIconLibrary} from '@fortawesome/angular-fontawesome';\nimport {faSpinner} from '@fortawesome/free-solid-svg-icons';\nimport {FileUploadModule} from 'ng2-file-upload';\nimport {NgxMaterialTimepickerModule} from 'ngx-material-timepicker';\n\nimport { CommentService } from './services/comment.service';\nimport { EntryService } from './services/entry.service';\nimport { UploadService } from './services/upload.service';\nimport { PrismService } from './services/prism.service';\nimport { IdentityService } from './services/identity.service';\nimport { DjangoRestFrameworkEndpointService } from './services/django-rest-framework-endpoint.service';\nimport {EntryRendererComponent} from './components/entry-renderer/entry-renderer.component';\nimport {EntryCreatorComponent} from './components/entry-creator/entry-creator.component';\nimport {OutlineViewComponent} from './components/outline-view/outline-view.component';\nimport {SideNavigationComponent} from './components/side-navigation/side-navigation.component';\nimport {LandingPageComponent} from './components/landing-page/landing-page.component';\nimport {JsonRendererComponent} from './components/json-renderer/json-renderer.component';\nimport {EntrySummaryComponent} from './components/entry-summary/entry-summary.component';\nimport { MediaUploadModalComponent } from './components/media-upload-modal/media-upload-modal.component';\nimport { EntrySelectorDialogComponent } from './components/entry-selector-dialog/entry-selector-dialog.component';\nimport {TimeAgoPipe} from './pipes/TimeAgoPipe';\nimport {LinkyPipe} from './pipes/LinkyPipe';\nimport { StaticHtmlComponent } from './components/static-html/static-html.component';\nimport {TagService} from './services/tag.service';\nimport { MainComponent } from './components/main/main.component';\nimport { EntryRendererWrapperComponent } from './components/entry-renderer-wrapper/entry-renderer-wrapper.component';\nimport {RouterModule} from '@angular/router';\nimport { SchedulePublishDialogComponent } from './components/schedule-publish-dialog/schedule-publish-dialog.component';\n\n\n@NgModule({\n    declarations: [\n        EntryRendererComponent,\n        EntryCreatorComponent,\n        LandingPageComponent,\n        SideNavigationComponent,\n        OutlineViewComponent,\n        JsonRendererComponent,\n        EntrySummaryComponent,\n        EntrySelectorDialogComponent,\n        MediaUploadModalComponent,\n        TimeAgoPipe,\n        LinkyPipe,\n        StaticHtmlComponent,\n        MainComponent,\n        EntryRendererWrapperComponent,\n        SchedulePublishDialogComponent,\n    ],\n    imports: [\n        CommonModule,\n        RouterModule,\n        FormsModule,\n        ReactiveFormsModule,\n        DragDropModule,\n        MatCardModule,\n        MatSidenavModule,\n        MatButtonModule,\n        MatInputModule,\n        MatListModule,\n        MatRadioModule,\n        MatDialogModule,\n        MatCheckboxModule,\n        MatDividerModule,\n        MatAutocompleteModule,\n        MatChipsModule,\n        MatIconModule,\n        MatDatepickerModule,\n        MatNativeDateModule,\n        MatTableModule,\n        MatProgressSpinnerModule,\n        FontAwesomeModule,\n        FileUploadModule,\n        NgxMaterialTimepickerModule,\n    ],\n    providers: [\n        CommentService,\n        EntryService,\n        UploadService,\n        PrismService,\n        IdentityService,\n        DjangoRestFrameworkEndpointService,\n        TagService,\n    ],\n    exports: [\n        EntryRendererComponent,\n        EntryCreatorComponent,\n        LandingPageComponent,\n        SideNavigationComponent,\n        OutlineViewComponent,\n        JsonRendererComponent,\n        EntrySummaryComponent,\n        EntrySelectorDialogComponent,\n        MediaUploadModalComponent,\n        TimeAgoPipe,\n        LinkyPipe,\n        StaticHtmlComponent,\n        MainComponent,\n        EntryRendererWrapperComponent,\n    ]\n})\nexport class CoreModule {\n    constructor(\n        private library: FaIconLibrary\n    ) {\n        this.library.addIcons(faSpinner);\n    }\n}\n"]}
@@ -62,6 +62,8 @@ import { DragDropModule } from '@angular/cdk/drag-drop';
62
62
  import { trigger, state, style, transition, animate } from '@angular/animations';
63
63
  import * as i8$1 from '@angular/material/list';
64
64
  import { MatListModule } from '@angular/material/list';
65
+ import * as i9$1 from '@angular/material/progress-spinner';
66
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
65
67
  import * as i3$1 from '@angular/material/sidenav';
66
68
  import { MatSidenavModule } from '@angular/material/sidenav';
67
69
  import Autolinker from 'autolinker';
@@ -1388,6 +1390,9 @@ class SideNavigationComponent {
1388
1390
  this.identityService = identityService;
1389
1391
  this.renderer = renderer;
1390
1392
  this.state = 'out';
1393
+ this.response = null;
1394
+ this.debounceTimeout = 200;
1395
+ this.loading = true;
1391
1396
  this.entries = [];
1392
1397
  this.entriesByMonthAndYear = [];
1393
1398
  this.searchTerm = "";
@@ -1395,7 +1400,7 @@ class SideNavigationComponent {
1395
1400
  this.searchControl = new FormControl('');
1396
1401
  }
1397
1402
  ngOnInit() {
1398
- this.doSearch.pipe(debounceTime(500)).subscribe((result) => {
1403
+ this.doSearch.pipe(debounceTime(this.debounceTimeout)).subscribe((result) => {
1399
1404
  this.searchEntries(result);
1400
1405
  });
1401
1406
  this.identityService.getMe().subscribe((identity) => {
@@ -1405,23 +1410,27 @@ class SideNavigationComponent {
1405
1410
  });
1406
1411
  this.getEntries();
1407
1412
  }
1408
- getEntriesWithUrl(url) {
1413
+ getMore() {
1414
+ this.getEntriesWithUrl(this.response.next, false);
1415
+ }
1416
+ getEntriesWithUrl(url, wipe = true) {
1417
+ this.loading = true;
1409
1418
  this.entryService.getListByUrl(url).subscribe((response) => {
1419
+ this.response = response;
1410
1420
  this.entries = this.entries.concat(map$1(response.results, (result) => {
1411
1421
  return { id: result.id, entry: new Entry(result) };
1412
1422
  }));
1413
- if (response.next) {
1414
- this.getEntriesWithUrl(response.next);
1415
- }
1416
- else {
1417
- this.organizeEntries();
1418
- }
1423
+ this.organizeEntries(wipe);
1419
1424
  });
1420
1425
  }
1421
- organizeEntries() {
1422
- this.state = 'out';
1426
+ organizeEntries(wipe = true) {
1427
+ if (wipe) {
1428
+ this.state = 'out';
1429
+ }
1423
1430
  let organizeEntriesFn = () => {
1424
- this.entriesByMonthAndYear = [];
1431
+ if (wipe) {
1432
+ this.entriesByMonthAndYear = [];
1433
+ }
1425
1434
  let newEntries = JSON.parse(JSON.stringify(this.entriesByMonthAndYear));
1426
1435
  for (const entryWrapper of this.entries) {
1427
1436
  const entry = entryWrapper.entry;
@@ -1449,37 +1458,37 @@ class SideNavigationComponent {
1449
1458
  newEntries.reverse();
1450
1459
  let setEntriesFn = () => {
1451
1460
  this.entriesByMonthAndYear = newEntries;
1452
- this.state = 'in';
1461
+ this.loading = false;
1462
+ if (wipe) {
1463
+ this.state = 'in';
1464
+ }
1453
1465
  };
1454
1466
  setTimeout(setEntriesFn.bind(this), 400);
1455
1467
  };
1456
1468
  setTimeout(organizeEntriesFn.bind(this), 400);
1457
1469
  }
1458
1470
  getEntries() {
1471
+ this.loading = true;
1459
1472
  this.entryService.get().subscribe((response) => {
1473
+ this.response = response;
1460
1474
  this.entries = map$1(response.results, (result) => {
1461
1475
  return { id: result.id, entry: new Entry(result) };
1462
1476
  });
1463
- if (response.next) {
1464
- this.getEntriesWithUrl(response.next);
1465
- }
1466
- else {
1467
- this.organizeEntries();
1468
- }
1477
+ this.organizeEntries();
1469
1478
  });
1470
1479
  }
1471
1480
  searchEntries(searchTerm) {
1481
+ let turnOnLoading = () => {
1482
+ this.loading = true;
1483
+ };
1484
+ setTimeout(turnOnLoading.bind(this), this.debounceTimeout + 100);
1472
1485
  if (searchTerm !== "") {
1473
1486
  this.entryService.search(searchTerm).subscribe((response) => {
1487
+ this.response = response;
1474
1488
  this.entries = map$1(response.results, (result) => {
1475
1489
  return { id: result.id, entry: new Entry(result) };
1476
1490
  });
1477
- if (response.next) {
1478
- this.getEntriesWithUrl(response.next);
1479
- }
1480
- else {
1481
- this.organizeEntries();
1482
- }
1491
+ this.organizeEntries();
1483
1492
  });
1484
1493
  }
1485
1494
  else {
@@ -1556,7 +1565,7 @@ class SideNavigationComponent {
1556
1565
  }
1557
1566
  }
1558
1567
  SideNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SideNavigationComponent, deps: [{ token: EntryService }, { token: i1$4.Router }, { token: IdentityService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
1559
- SideNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SideNavigationComponent, selector: "app-side-navigation", viewQueries: [{ propertyName: "divNav", first: true, predicate: ["navcontainer"], descendants: true }], ngImport: i0, template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n </div>\n\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".sidenav{max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"], dependencies: [{ kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "component", type: i8$1.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i8$1.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }], animations: [
1568
+ SideNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SideNavigationComponent, selector: "app-side-navigation", viewQueries: [{ propertyName: "divNav", first: true, predicate: ["navcontainer"], descendants: true }], ngImport: i0, template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div\n class=\"progress\"\n [hidden]=\"!loading\"\n >\n <mat-progress-spinner\n style=\"margin-left: 16px;\"\n [diameter]=20\n mode=\"indeterminate\"\n >\n </mat-progress-spinner>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n <a\n class=\"sidelink\"\n *ngIf=\"this?.response?.next && !loading\"\n (click)=\"getMore()\"\n href=\"javascript:void(0);\">More...</a>\n </div>\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".progress{position:absolute;top:100px;left:0}.sidelink{padding-left:16px}.sidenav{position:relative;max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"], dependencies: [{ kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "component", type: i8$1.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i8$1.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "component", type: i9$1.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }], animations: [
1560
1569
  trigger('sideNavAnimation', [
1561
1570
  state('in', style({ transform: 'translateX(0%)' })),
1562
1571
  state('out', style({ transform: 'translateX(110%)' })),
@@ -1581,7 +1590,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
1581
1590
  animate('100ms ease-in', style({ transform: 'translateX(0%)' }))
1582
1591
  ])
1583
1592
  ]),
1584
- ], template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n </div>\n\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".sidenav{max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"] }]
1593
+ ], template: "<div class=\"sidenav no-scrollbar\">\n <div style=\"margin-top: 20px;\">\n <mat-form-field style=\"width: 100%\">\n <mat-label>Search</mat-label>\n <input matInput [formControl]=\"searchControl\" (ngModelChange)=\"onSearchChange($event)\">\n </mat-form-field>\n </div>\n\n <div\n class=\"progress\"\n [hidden]=\"!loading\"\n >\n <mat-progress-spinner\n style=\"margin-left: 16px;\"\n [diameter]=20\n mode=\"indeterminate\"\n >\n </mat-progress-spinner>\n </div>\n\n <div #navcontainer class=\"navcontainer\"\n [@sideNavAnimation]=\"state\"\n >\n <mat-nav-list\n *ngFor=\"let container of entriesByMonthAndYear\"\n >\n <h3>{{getMonthAndYearFromKey(container.month_year)}}</h3>\n <a mat-list-item *ngFor=\"let entry of container.entries\" href=\"javascript:void(0)\" (click)=\"routeTo(entry)\">{{entry.title}}</a>\n </mat-nav-list>\n\n <a\n class=\"sidelink\"\n *ngIf=\"this?.response?.next && !loading\"\n (click)=\"getMore()\"\n href=\"javascript:void(0);\">More...</a>\n </div>\n <ng-container *ngIf=\"identity?.id === 1\">\n <h2>Misc</h2>\n\n <mat-nav-list>\n <a mat-list-item href=\"javascript:void(0);\" (click)=\"routeTo(null)\">Create</a>\n </mat-nav-list>\n </ng-container>\n <h3 *ngIf=\"identity\">Logged in as {{identity?.email}}</h3>\n</div>\n\n", styles: [".progress{position:absolute;top:100px;left:0}.sidelink{padding-left:16px}.sidenav{position:relative;max-height:calc(100vh - 100px)}@media screen and (max-height: 560px){.sidenav{max-height:100vh}}h2,h3{margin-left:10px;justify-content:right}\n"] }]
1585
1594
  }], ctorParameters: function () { return [{ type: EntryService }, { type: i1$4.Router }, { type: IdentityService }, { type: i0.Renderer2 }]; }, propDecorators: { divNav: [{
1586
1595
  type: ViewChild,
1587
1596
  args: ['navcontainer', { static: false }]
@@ -1798,6 +1807,7 @@ CoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15
1798
1807
  MatDatepickerModule,
1799
1808
  MatNativeDateModule,
1800
1809
  MatTableModule,
1810
+ MatProgressSpinnerModule,
1801
1811
  FontAwesomeModule,
1802
1812
  FileUploadModule,
1803
1813
  NgxMaterialTimepickerModule], exports: [EntryRendererComponent,
@@ -1842,6 +1852,7 @@ CoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15
1842
1852
  MatDatepickerModule,
1843
1853
  MatNativeDateModule,
1844
1854
  MatTableModule,
1855
+ MatProgressSpinnerModule,
1845
1856
  FontAwesomeModule,
1846
1857
  FileUploadModule,
1847
1858
  NgxMaterialTimepickerModule] });
@@ -1886,6 +1897,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
1886
1897
  MatDatepickerModule,
1887
1898
  MatNativeDateModule,
1888
1899
  MatTableModule,
1900
+ MatProgressSpinnerModule,
1889
1901
  FontAwesomeModule,
1890
1902
  FileUploadModule,
1891
1903
  NgxMaterialTimepickerModule,