@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.
- package/esm2020/lib/components/side-navigation/side-navigation.component.mjs +35 -27
- package/esm2020/lib/core.module.mjs +5 -1
- package/fesm2015/thecodeblogs-blog.mjs +38 -26
- package/fesm2015/thecodeblogs-blog.mjs.map +1 -1
- package/fesm2020/thecodeblogs-blog.mjs +38 -26
- package/fesm2020/thecodeblogs-blog.mjs.map +1 -1
- package/lib/components/side-navigation/side-navigation.component.d.ts +7 -2
- package/lib/core.module.d.ts +5 -4
- package/package.json +1 -1
|
@@ -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(
|
|
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
|
-
|
|
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
|
-
|
|
47
|
-
this.getEntriesWithUrl(response.next);
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
this.organizeEntries();
|
|
51
|
-
}
|
|
55
|
+
this.organizeEntries(wipe);
|
|
52
56
|
});
|
|
53
57
|
}
|
|
54
|
-
organizeEntries() {
|
|
55
|
-
|
|
58
|
+
organizeEntries(wipe = true) {
|
|
59
|
+
if (wipe) {
|
|
60
|
+
this.state = 'out';
|
|
61
|
+
}
|
|
56
62
|
let organizeEntriesFn = () => {
|
|
57
|
-
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
|
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(
|
|
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
|
-
|
|
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
|
-
|
|
1414
|
-
this.getEntriesWithUrl(response.next);
|
|
1415
|
-
}
|
|
1416
|
-
else {
|
|
1417
|
-
this.organizeEntries();
|
|
1418
|
-
}
|
|
1423
|
+
this.organizeEntries(wipe);
|
|
1419
1424
|
});
|
|
1420
1425
|
}
|
|
1421
|
-
organizeEntries() {
|
|
1422
|
-
|
|
1426
|
+
organizeEntries(wipe = true) {
|
|
1427
|
+
if (wipe) {
|
|
1428
|
+
this.state = 'out';
|
|
1429
|
+
}
|
|
1423
1430
|
let organizeEntriesFn = () => {
|
|
1424
|
-
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
|
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,
|