@thecodeblogs/blog 0.15.4 → 0.19.0

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.
Files changed (70) hide show
  1. package/fesm2022/thecodeblogs-blog.mjs +2018 -0
  2. package/fesm2022/thecodeblogs-blog.mjs.map +1 -0
  3. package/lib/components/entry-creator/entry-creator.component.d.ts +1 -1
  4. package/lib/components/entry-renderer/entry-renderer.component.d.ts +1 -1
  5. package/lib/components/entry-renderer-wrapper/entry-renderer-wrapper.component.d.ts +1 -1
  6. package/lib/components/entry-selector-dialog/entry-selector-dialog.component.d.ts +1 -1
  7. package/lib/components/entry-summary/entry-summary.component.d.ts +1 -1
  8. package/lib/components/json-renderer/json-renderer.component.d.ts +1 -1
  9. package/lib/components/landing-page/landing-page.component.d.ts +1 -1
  10. package/lib/components/main/main.component.d.ts +1 -1
  11. package/lib/components/media-upload-modal/media-upload-modal.component.d.ts +4 -2
  12. package/lib/components/outline-view/outline-view.component.d.ts +1 -1
  13. package/lib/components/schedule-publish-dialog/schedule-publish-dialog.component.d.ts +1 -1
  14. package/lib/components/side-navigation/side-navigation.component.d.ts +8 -3
  15. package/lib/components/static-html/static-html.component.d.ts +1 -1
  16. package/lib/core.module.d.ts +38 -38
  17. package/lib/pipes/LinkyPipe.d.ts +1 -1
  18. package/lib/pipes/TimeAgoPipe.d.ts +1 -1
  19. package/package.json +22 -26
  20. package/esm2020/lib/components/entry-creator/entry-creator.component.mjs +0 -341
  21. package/esm2020/lib/components/entry-renderer/entry-renderer.component.mjs +0 -108
  22. package/esm2020/lib/components/entry-renderer-wrapper/entry-renderer-wrapper.component.mjs +0 -75
  23. package/esm2020/lib/components/entry-selector-dialog/entry-selector-dialog-data.mjs +0 -3
  24. package/esm2020/lib/components/entry-selector-dialog/entry-selector-dialog.component.mjs +0 -54
  25. package/esm2020/lib/components/entry-summary/entry-summary.component.mjs +0 -28
  26. package/esm2020/lib/components/json-renderer/json-renderer.component.mjs +0 -26
  27. package/esm2020/lib/components/landing-page/landing-page.component.mjs +0 -35
  28. package/esm2020/lib/components/main/main.component.mjs +0 -56
  29. package/esm2020/lib/components/media-upload-modal/media-upload-modal.component.mjs +0 -160
  30. package/esm2020/lib/components/outline-view/outline-view.component.mjs +0 -38
  31. package/esm2020/lib/components/schedule-publish-dialog/schedule-publish-dialog-data.mjs +0 -3
  32. package/esm2020/lib/components/schedule-publish-dialog/schedule-publish-dialog.component.mjs +0 -33
  33. package/esm2020/lib/components/side-navigation/side-navigation.component.mjs +0 -222
  34. package/esm2020/lib/components/static-html/static-html.component.mjs +0 -28
  35. package/esm2020/lib/core.module.mjs +0 -209
  36. package/esm2020/lib/data/base.mjs +0 -7
  37. package/esm2020/lib/data/content-type.mjs +0 -10
  38. package/esm2020/lib/data/content.mjs +0 -5
  39. package/esm2020/lib/data/core-event-type.enum.mjs +0 -7
  40. package/esm2020/lib/data/core-event.mjs +0 -7
  41. package/esm2020/lib/data/entry.mjs +0 -79
  42. package/esm2020/lib/data/guid.mjs +0 -12
  43. package/esm2020/lib/data/identity.mjs +0 -2
  44. package/esm2020/lib/data/list-response.mjs +0 -3
  45. package/esm2020/lib/data/section.mjs +0 -11
  46. package/esm2020/lib/data/tag.mjs +0 -7
  47. package/esm2020/lib/data/visitor-profile.mjs +0 -3
  48. package/esm2020/lib/pipes/LinkyPipe.mjs +0 -15
  49. package/esm2020/lib/pipes/TimeAgoPipe.mjs +0 -100
  50. package/esm2020/lib/routing/routes.mjs +0 -25
  51. package/esm2020/lib/services/analytics/interaction.service.mjs +0 -20
  52. package/esm2020/lib/services/analytics/view.service.mjs +0 -20
  53. package/esm2020/lib/services/comment.service.mjs +0 -28
  54. package/esm2020/lib/services/django-rest-framework-endpoint.service.mjs +0 -50
  55. package/esm2020/lib/services/entry.service.mjs +0 -106
  56. package/esm2020/lib/services/identity.service.mjs +0 -20
  57. package/esm2020/lib/services/interaction.mjs +0 -3
  58. package/esm2020/lib/services/prism.service.mjs +0 -39
  59. package/esm2020/lib/services/static-html.service.mjs +0 -22
  60. package/esm2020/lib/services/tag.service.mjs +0 -33
  61. package/esm2020/lib/services/upload.mjs +0 -3
  62. package/esm2020/lib/services/upload.service.mjs +0 -22
  63. package/esm2020/lib/services/view.mjs +0 -3
  64. package/esm2020/lib/services/visitor-profile.service.mjs +0 -35
  65. package/esm2020/public-api.mjs +0 -45
  66. package/esm2020/thecodeblogs-blog.mjs +0 -5
  67. package/fesm2015/thecodeblogs-blog.mjs +0 -1930
  68. package/fesm2015/thecodeblogs-blog.mjs.map +0 -1
  69. package/fesm2020/thecodeblogs-blog.mjs +0 -1924
  70. package/fesm2020/thecodeblogs-blog.mjs.map +0 -1
@@ -1,160 +0,0 @@
1
- import { Component, HostListener, Input } from '@angular/core';
2
- import { FileUploader } from 'ng2-file-upload';
3
- import { UploadService } from '../../services/upload.service';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/dialog";
6
- import * as i2 from "../../services/upload.service";
7
- import * as i3 from "@angular/common";
8
- import * as i4 from "@angular/material/button";
9
- import * as i5 from "@angular/material/divider";
10
- import * as i6 from "@fortawesome/angular-fontawesome";
11
- import * as i7 from "ng2-file-upload";
12
- export class MediaUploadModalComponent {
13
- static getCookie(name) {
14
- const ca = document.cookie.split(';');
15
- const caLen = ca.length;
16
- const cookieName = `${name}=`;
17
- let c;
18
- for (let i = 0; i < caLen; i += 1) {
19
- c = ca[i].replace(/^\s+/g, '');
20
- if (c.indexOf(cookieName) === 0) {
21
- return c.substring(cookieName.length, c.length);
22
- }
23
- }
24
- return '';
25
- }
26
- constructor(dialogRef, uploadService) {
27
- this.dialogRef = dialogRef;
28
- this.uploadService = uploadService;
29
- this.allowedMimeTypes = [
30
- 'image/jpeg',
31
- 'image/gif',
32
- 'image/png',
33
- 'image/jpg',
34
- 'video/mp4',
35
- 'video/webm',
36
- 'video/ogg',
37
- ];
38
- this.uploadUrlKey = 'path_to_file';
39
- this.uploading = false;
40
- }
41
- pollForCompletion() {
42
- this.uploadService.get(this.uploadId).subscribe((response) => {
43
- if (response.processed) {
44
- this.imgLink = response[this.uploadUrlKey];
45
- this.mimeType = response.mime_type;
46
- clearInterval(this.poller);
47
- this.poller = null;
48
- this.uploading = false;
49
- }
50
- });
51
- }
52
- ngOnInit() {
53
- this.uploader = new FileUploader({
54
- url: UploadService.upload_endpoint,
55
- itemAlias: 'file',
56
- authToken: '',
57
- headers: [
58
- { name: 'X-CSRFToken', value: MediaUploadModalComponent.getCookie('csrftoken') },
59
- ],
60
- additionalParameter: { csrf_token: MediaUploadModalComponent.getCookie('csrftoken') },
61
- removeAfterUpload: true,
62
- allowedMimeType: this.allowedMimeTypes,
63
- });
64
- this.uploader.onCompleteItem = (item, response) => {
65
- const responseObj = JSON.parse(response);
66
- this.uploadId = responseObj.id;
67
- this.poller = setInterval(this.pollForCompletion.bind(this), 2000);
68
- };
69
- this.uploader.onWhenAddingFileFailed = (item, filter, options) => {
70
- this.error = 'This file is not a supported mimetype.';
71
- this.uploading = false;
72
- };
73
- if (this.file) {
74
- this.uploader.addToQueue([this.file]);
75
- this.uploader.uploadAll();
76
- this.uploading = true;
77
- }
78
- }
79
- onFileSelected(e) {
80
- this.uploader.uploadAll();
81
- this.uploading = true;
82
- }
83
- buildHost(url) {
84
- return location.protocol + '//' + location.hostname + (location.port ? ':' + location.port : '') + url;
85
- }
86
- close() {
87
- this.dialogRef.close();
88
- }
89
- ngOnDestroy() {
90
- if (this.socketSub) {
91
- this.socketSub.complete();
92
- this.socketSub = null;
93
- }
94
- }
95
- blobToFile(theBlob, fileName) {
96
- // A Blob() is almost a File() - it's just missing the two properties below which we will add
97
- theBlob.lastModifiedDate = new Date();
98
- theBlob.name = fileName;
99
- return theBlob;
100
- }
101
- onPaste(e) {
102
- if (e instanceof ClipboardEvent) {
103
- const files = e.clipboardData.files;
104
- if (files) {
105
- if (files.length < 1) {
106
- // const items = e.clipboardData.items;
107
- // for(let i = 0; i < items.length; i++) {
108
- // const item = items[i];
109
- // item.getAsString((text) => {
110
- // try {
111
- // const url = new URL(text);
112
- // if(url) {
113
- // fetch(text)
114
- // .then(res => res.blob()) // Gets the response and returns it as a blob
115
- // .then(blob => {
116
- // const file = this.blobToFile(blob, 'web-created')
117
- // this.uploader.addToQueue([file])
118
- // this.uploader.uploadAll();
119
- // this.uploading = true;
120
- // });
121
- // }
122
- // } catch(e) {
123
- //
124
- // }
125
- // });
126
- // }
127
- }
128
- else if (files.length > 1) {
129
- console.log('Multiple files detected');
130
- }
131
- else {
132
- for (let i = 0; i < files.length; i++) {
133
- this.uploader.addToQueue([files[i]]);
134
- }
135
- this.uploader.uploadAll();
136
- this.uploading = true;
137
- }
138
- }
139
- else {
140
- console.log('Stuff not working');
141
- }
142
- }
143
- }
144
- }
145
- MediaUploadModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: MediaUploadModalComponent, deps: [{ token: i1.MatDialogRef }, { token: i2.UploadService }], target: i0.ɵɵFactoryTarget.Component });
146
- MediaUploadModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: MediaUploadModalComponent, selector: "app-media-upload-modal", inputs: { allowedMimeTypes: "allowedMimeTypes", uploadUrlKey: "uploadUrlKey", file: "file" }, host: { listeners: { "document:paste": "onPaste($event)" } }, ngImport: i0, template: "<h1 mat-dialog-title>Upload an Image</h1>\n<!--<mat-radio-group aria-label=\"Select an option\">-->\n<!-- <mat-radio-button class=\"option\" value=\"unpublished\">Unpublished</mat-radio-button>-->\n<!-- <mat-radio-button class=\"option\" value=\"published\">Published</mat-radio-button>-->\n<!--</mat-radio-group>-->\n<mat-divider class=\"option-list-divider\"></mat-divider>\n<div mat-dialog-content>\n <div *ngIf=\"uploading\">\n <fa-icon [icon]=\"'spinner'\" [spin]=\"true\"></fa-icon>\n </div>\n <ng-container *ngIf=\"!imgLink && !uploading\">\n <h4>Select a File</h4>\n <div class=\"input-group\">\n <div class=\"form-group\">\n <!-- <label for=\"import_file\">Choose File</label>-->\n <input type=\"file\" id=\"import_file\"\n *ngIf=\"uploader.queue.length==0 && !uploading\"\n ng2FileSelect\n [uploader]=\"uploader\"\n (onFileSelected)=\"onFileSelected($event)\"\n >\n </div>\n </div>\n <br>\n <h3>Paste a File</h3>\n <p>You can use the paste command to paste any image here</p>\n </ng-container>\n <div *ngIf=\"imgLink\">\n <img *ngIf=\"imgLink\" [src]=\"imgLink\"/>\n </div>\n <div *ngIf=\"error\">\n <div class=\"alert alert-danger\">\n {{error}}\n </div>\n </div>\n</div>\n<div mat-dialog-actions>\n <button mat-button [disabled]=\"!imgLink || uploading\" (click)=\"close()\">Attach</button>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i6.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "directive", type: i7.FileSelectDirective, selector: "[ng2FileSelect]", inputs: ["uploader"], outputs: ["onFileSelected"] }] });
147
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: MediaUploadModalComponent, decorators: [{
148
- type: Component,
149
- args: [{ selector: 'app-media-upload-modal', template: "<h1 mat-dialog-title>Upload an Image</h1>\n<!--<mat-radio-group aria-label=\"Select an option\">-->\n<!-- <mat-radio-button class=\"option\" value=\"unpublished\">Unpublished</mat-radio-button>-->\n<!-- <mat-radio-button class=\"option\" value=\"published\">Published</mat-radio-button>-->\n<!--</mat-radio-group>-->\n<mat-divider class=\"option-list-divider\"></mat-divider>\n<div mat-dialog-content>\n <div *ngIf=\"uploading\">\n <fa-icon [icon]=\"'spinner'\" [spin]=\"true\"></fa-icon>\n </div>\n <ng-container *ngIf=\"!imgLink && !uploading\">\n <h4>Select a File</h4>\n <div class=\"input-group\">\n <div class=\"form-group\">\n <!-- <label for=\"import_file\">Choose File</label>-->\n <input type=\"file\" id=\"import_file\"\n *ngIf=\"uploader.queue.length==0 && !uploading\"\n ng2FileSelect\n [uploader]=\"uploader\"\n (onFileSelected)=\"onFileSelected($event)\"\n >\n </div>\n </div>\n <br>\n <h3>Paste a File</h3>\n <p>You can use the paste command to paste any image here</p>\n </ng-container>\n <div *ngIf=\"imgLink\">\n <img *ngIf=\"imgLink\" [src]=\"imgLink\"/>\n </div>\n <div *ngIf=\"error\">\n <div class=\"alert alert-danger\">\n {{error}}\n </div>\n </div>\n</div>\n<div mat-dialog-actions>\n <button mat-button [disabled]=\"!imgLink || uploading\" (click)=\"close()\">Attach</button>\n</div>\n" }]
150
- }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: i2.UploadService }]; }, propDecorators: { allowedMimeTypes: [{
151
- type: Input
152
- }], uploadUrlKey: [{
153
- type: Input
154
- }], file: [{
155
- type: Input
156
- }], onPaste: [{
157
- type: HostListener,
158
- args: ['document:paste', ['$event']]
159
- }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-upload-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/components/media-upload-modal/media-upload-modal.component.ts","../../../../../../projects/core/src/lib/components/media-upload-modal/media-upload-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAC;AAChF,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAI7C,OAAO,EAAC,aAAa,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;AAO5D,MAAM,OAAO,yBAAyB;IAyBlC,MAAM,CAAC,SAAS,CAAC,IAAY;QACzB,MAAM,EAAE,GAAkB,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACrD,MAAM,KAAK,GAAW,EAAE,CAAC,MAAM,CAAC;QAChC,MAAM,UAAU,GAAG,GAAG,IAAI,GAAG,CAAC;QAC9B,IAAI,CAAS,CAAC;QAEd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE;YAC/B,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YAC/B,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;gBAC7B,OAAO,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;aACnD;SACJ;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAED,YACW,SAAkD,EACjD,aAA4B;QAD7B,cAAS,GAAT,SAAS,CAAyC;QACjD,kBAAa,GAAb,aAAa,CAAe;QAxC/B,qBAAgB,GAAG;YAChB,YAAY;YACZ,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,YAAY;YACZ,WAAW;SACtB,CAAC;QAEO,iBAAY,GAAG,cAAc,CAAC;QAQvC,cAAS,GAAG,KAAK,CAAC;IAwBlB,CAAC;IAGD,iBAAiB;QACb,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACzD,IAAI,QAAQ,CAAC,SAAS,EAAE;gBACpB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC3C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,SAAS,CAAC;gBACnC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC3B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;aAC1B;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAGD,QAAQ;QAEJ,IAAI,CAAC,QAAQ,GAAG,IAAI,YAAY,CAC5B;YACI,GAAG,EAAE,aAAa,CAAC,eAAe;YAClC,SAAS,EAAE,MAAM;YACjB,SAAS,EAAE,EAAE;YACb,OAAO,EAAE;gBACL,EAAC,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,yBAAyB,CAAC,SAAS,CAAC,WAAW,CAAC,EAAC;aACjF;YACD,mBAAmB,EAAE,EAAC,UAAU,EAAE,yBAAyB,CAAC,SAAS,CAAC,WAAW,CAAC,EAAC;YACnF,iBAAiB,EAAE,IAAI;YACvB,eAAe,EAAE,IAAI,CAAC,gBAAgB;SACzC,CACJ,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,cAAc,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;YAC9C,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACzC,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,EAAE,CAAC;YAC/B,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACvE,CAAC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,sBAAsB,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE;YAC7D,IAAI,CAAC,KAAK,GAAG,wCAAwC,CAAC;YACtD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAC3B,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACzB;IACL,CAAC;IAED,cAAc,CAAC,CAAC;QACZ,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,SAAS,CAAC,GAAG;QACT,OAAO,QAAQ,CAAC,QAAQ,GAAG,IAAI,GAAG,QAAQ,CAAC,QAAQ,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;IAC3G,CAAC;IAED,KAAK;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACzB;IACL,CAAC;IAED,UAAU,CAAC,OAAO,EAAE,QAAQ;QACxB,6FAA6F;QAC7F,OAAO,CAAC,gBAAgB,GAAG,IAAI,IAAI,EAAE,CAAC;QACtC,OAAO,CAAC,IAAI,GAAG,QAAQ,CAAC;QACxB,OAAO,OAAO,CAAC;IACnB,CAAC;IAGD,OAAO,CAAC,CAAC;QACL,IAAI,CAAC,YAAY,cAAc,EAAE;YAC7B,MAAM,KAAK,GAAG,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC;YACpC,IAAI,KAAK,EAAE;gBACP,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;oBAClB,uCAAuC;oBACvC,0CAA0C;oBAC1C,6BAA6B;oBAC7B,mCAAmC;oBACnC,gBAAgB;oBAChB,yCAAyC;oBACzC,wBAAwB;oBACxB,8BAA8B;oBAC9B,6FAA6F;oBAC7F,sCAAsC;oBACtC,4EAA4E;oBAC5E,2DAA2D;oBAC3D,qDAAqD;oBACrD,iDAAiD;oBACjD,0BAA0B;oBAC1B,gBAAgB;oBAChB,uBAAuB;oBACvB,EAAE;oBACF,YAAY;oBACZ,UAAU;oBACV,IAAI;iBACP;qBAAM,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;oBACzB,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;iBAC1C;qBAAM;oBACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACnC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;qBACxC;oBACD,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;oBAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;iBACzB;aACJ;iBAAM;gBACH,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;aACpC;SACJ;IACL,CAAC;;sHAjKQ,yBAAyB;0GAAzB,yBAAyB,0NCZtC,8jDAuCA;2FD3Ba,yBAAyB;kBALrC,SAAS;+BACI,wBAAwB;+HAMzB,gBAAgB;sBAAxB,KAAK;gBAUG,YAAY;sBAApB,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBAqGN,OAAO;sBADN,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {Component, HostListener, Input, OnInit, OnDestroy} from '@angular/core';\nimport {FileUploader} from 'ng2-file-upload';\nimport {MatDialogRef} from '@angular/material/dialog';\n\nimport {DjangoRestFrameworkEndpointService} from '../../services/django-rest-framework-endpoint.service';\nimport {UploadService} from '../../services/upload.service';\n\n@Component({\n    selector: 'app-media-upload-modal',\n    templateUrl: './media-upload-modal.component.html',\n    styleUrls: ['./media-upload-modal.component.css']\n})\nexport class MediaUploadModalComponent implements OnInit, OnDestroy {\n\n    @Input() allowedMimeTypes = [\n                'image/jpeg',\n                'image/gif',\n                'image/png',\n                'image/jpg',\n                'video/mp4',\n                'video/webm',\n                'video/ogg',\n    ];\n\n    @Input() uploadUrlKey = 'path_to_file';\n\n    imgLink;\n    mimeType;\n    socketSub;\n    error;\n    public uploader: FileUploader;\n    uploadId;\n    uploading = false;\n    @Input() file;\n\n    poller;\n\n    static getCookie(name: string) {\n        const ca: Array<string> = document.cookie.split(';');\n        const caLen: number = ca.length;\n        const cookieName = `${name}=`;\n        let c: string;\n\n        for (let i = 0; i < caLen; i += 1) {\n            c = ca[i].replace(/^\\s+/g, '');\n            if (c.indexOf(cookieName) === 0) {\n                return c.substring(cookieName.length, c.length);\n            }\n        }\n        return '';\n    }\n\n    constructor(\n        public dialogRef: MatDialogRef<MediaUploadModalComponent>,\n        private uploadService: UploadService\n    ) {\n    }\n\n\n    pollForCompletion() {\n        this.uploadService.get(this.uploadId).subscribe((response) => {\n            if (response.processed) {\n                this.imgLink = response[this.uploadUrlKey];\n                this.mimeType = response.mime_type;\n                clearInterval(this.poller);\n                this.poller = null;\n                this.uploading = false;\n            }\n        });\n    }\n\n\n    ngOnInit(): void {\n\n        this.uploader = new FileUploader(\n            {\n                url: UploadService.upload_endpoint,\n                itemAlias: 'file',\n                authToken: '',\n                headers: [\n                    {name: 'X-CSRFToken', value: MediaUploadModalComponent.getCookie('csrftoken')},\n                ],\n                additionalParameter: {csrf_token: MediaUploadModalComponent.getCookie('csrftoken')},\n                removeAfterUpload: true,\n                allowedMimeType: this.allowedMimeTypes,\n            }\n        );\n\n        this.uploader.onCompleteItem = (item, response) => {\n            const responseObj = JSON.parse(response);\n            this.uploadId = responseObj.id;\n            this.poller = setInterval(this.pollForCompletion.bind(this), 2000);\n        };\n\n        this.uploader.onWhenAddingFileFailed = (item, filter, options) => {\n            this.error = 'This file is not a supported mimetype.';\n            this.uploading = false;\n        };\n\n        if (this.file) {\n            this.uploader.addToQueue([this.file]);\n            this.uploader.uploadAll();\n            this.uploading = true;\n        }\n    }\n\n    onFileSelected(e) {\n        this.uploader.uploadAll();\n        this.uploading = true;\n    }\n\n    buildHost(url) {\n        return location.protocol + '//' + location.hostname + (location.port ? ':' + location.port : '') + url;\n    }\n\n    close() {\n        this.dialogRef.close();\n    }\n\n    ngOnDestroy(): void {\n        if (this.socketSub) {\n            this.socketSub.complete();\n            this.socketSub = null;\n        }\n    }\n\n    blobToFile(theBlob, fileName) {\n        // A Blob() is almost a File() - it's just missing the two properties below which we will add\n        theBlob.lastModifiedDate = new Date();\n        theBlob.name = fileName;\n        return theBlob;\n    }\n\n    @HostListener('document:paste', ['$event'])\n    onPaste(e) {\n        if (e instanceof ClipboardEvent) {\n            const files = e.clipboardData.files;\n            if (files) {\n                if (files.length < 1) {\n                    // const items = e.clipboardData.items;\n                    // for(let i = 0; i < items.length; i++) {\n                    //     const item = items[i];\n                    //     item.getAsString((text) => {\n                    //         try {\n                    //             const url = new URL(text);\n                    //             if(url) {\n                    //                 fetch(text)\n                    //                     .then(res => res.blob()) // Gets the response and returns it as a blob\n                    //                     .then(blob => {\n                    //                         const file = this.blobToFile(blob, 'web-created')\n                    //                         this.uploader.addToQueue([file])\n                    //                         this.uploader.uploadAll();\n                    //                         this.uploading = true;\n                    //                     });\n                    //             }\n                    //         } catch(e) {\n                    //\n                    //         }\n                    //     });\n                    // }\n                } else if (files.length > 1) {\n                    console.log('Multiple files detected');\n                } else {\n                    for (let i = 0; i < files.length; i++) {\n                        this.uploader.addToQueue([files[i]]);\n                    }\n                    this.uploader.uploadAll();\n                    this.uploading = true;\n                }\n            } else {\n                console.log('Stuff not working');\n            }\n        }\n    }\n}\n","<h1 mat-dialog-title>Upload an Image</h1>\n<!--<mat-radio-group aria-label=\"Select an option\">-->\n<!--    <mat-radio-button class=\"option\" value=\"unpublished\">Unpublished</mat-radio-button>-->\n<!--    <mat-radio-button class=\"option\" value=\"published\">Published</mat-radio-button>-->\n<!--</mat-radio-group>-->\n<mat-divider class=\"option-list-divider\"></mat-divider>\n<div mat-dialog-content>\n    <div *ngIf=\"uploading\">\n        <fa-icon [icon]=\"'spinner'\" [spin]=\"true\"></fa-icon>\n    </div>\n    <ng-container *ngIf=\"!imgLink && !uploading\">\n        <h4>Select a File</h4>\n        <div class=\"input-group\">\n            <div class=\"form-group\">\n                <!--                <label for=\"import_file\">Choose File</label>-->\n                <input type=\"file\" id=\"import_file\"\n                       *ngIf=\"uploader.queue.length==0 && !uploading\"\n                       ng2FileSelect\n                       [uploader]=\"uploader\"\n                       (onFileSelected)=\"onFileSelected($event)\"\n                >\n            </div>\n        </div>\n        <br>\n        <h3>Paste a File</h3>\n        <p>You can use the paste command to paste any image here</p>\n    </ng-container>\n    <div *ngIf=\"imgLink\">\n        <img *ngIf=\"imgLink\" [src]=\"imgLink\"/>\n    </div>\n    <div *ngIf=\"error\">\n        <div class=\"alert alert-danger\">\n            {{error}}\n        </div>\n    </div>\n</div>\n<div mat-dialog-actions>\n    <button mat-button [disabled]=\"!imgLink || uploading\" (click)=\"close()\">Attach</button>\n</div>\n"]}
@@ -1,38 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/entry.service";
4
- import * as i2 from "@angular/common";
5
- import * as i3 from "@angular/cdk/drag-drop";
6
- import * as i4 from "@angular/material/card";
7
- export class OutlineViewComponent {
8
- constructor(entryService) {
9
- this.entryService = entryService;
10
- this.Math = Math;
11
- }
12
- ngOnInit() {
13
- this.entryService.currentlyEditedEntry.subscribe((entry) => {
14
- this.entry = entry;
15
- });
16
- }
17
- sectionDrop(e) {
18
- const entry = this.entry;
19
- const diff = e.currentIndex - e.previousIndex;
20
- entry.sections[e.previousIndex].order = e.currentIndex * 10 + (diff > 0 ? 1 : -1);
21
- entry.sort();
22
- this.entryService.currentlyEditedEntry.next(this.entry);
23
- }
24
- contentDrop(e, section) {
25
- const entry = this.entry;
26
- const diff = e.currentIndex - e.previousIndex;
27
- section.contents[e.previousIndex].order = e.currentIndex * 10 + (diff > 0 ? 1 : -1);
28
- entry.sort();
29
- this.entryService.currentlyEditedEntry.next(this.entry);
30
- }
31
- }
32
- OutlineViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: OutlineViewComponent, deps: [{ token: i1.EntryService }], target: i0.ɵɵFactoryTarget.Component });
33
- OutlineViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: OutlineViewComponent, selector: "app-outline-view", ngImport: i0, template: "<div *ngIf=\"entry\" class=\"section outline\">\n <h1 *ngIf=\"entry?.sections?.length === 0\">Outline View</h1>\n <div cdkDropList class=\"sections\" (cdkDropListDropped)=\"sectionDrop($event)\">\n <mat-card class=\"card\" cdkDrag *ngFor=\"let section of entry.sections\">\n <h3>Section {{Math.ceil(section.order / 10) + 1}}</h3>\n {{section.subheading}}\n <div cdkDropList class=\"contents\" (cdkDropListDropped)=\"contentDrop($event, section)\">\n <h3>Contents for {{section.subheading}}</h3>\n <div class=\"content-card\" *ngFor=\"let content of section.contents\" cdkDrag>\n <div class=\"content\">{{content.value}}</div>\n <div class=\"content-placeholder\" *cdkDragPlaceholder></div>\n </div>\n </div>\n </mat-card>\n <div class=\"custom-placeholder\" *cdkDragPlaceholder></div>\n </div>\n</div>\n", styles: [".outline{padding:0 20px}.content{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.card,.content-card{margin:4px;cursor:pointer}.content-card:not(:last-child){border-bottom:1px dotted #aaa}.custom-placeholder{background:#ccc;border:dotted 3px #999;transition:transform .25s cubic-bezier(0,0,.2,1);min-height:60px}.content-placeholder{background:#ccc;border:dotted 3px #999;transition:transform .25s cubic-bezier(0,0,.2,1);min-height:30px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i3.CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "component", type: i4.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }] });
34
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: OutlineViewComponent, decorators: [{
35
- type: Component,
36
- args: [{ selector: 'app-outline-view', template: "<div *ngIf=\"entry\" class=\"section outline\">\n <h1 *ngIf=\"entry?.sections?.length === 0\">Outline View</h1>\n <div cdkDropList class=\"sections\" (cdkDropListDropped)=\"sectionDrop($event)\">\n <mat-card class=\"card\" cdkDrag *ngFor=\"let section of entry.sections\">\n <h3>Section {{Math.ceil(section.order / 10) + 1}}</h3>\n {{section.subheading}}\n <div cdkDropList class=\"contents\" (cdkDropListDropped)=\"contentDrop($event, section)\">\n <h3>Contents for {{section.subheading}}</h3>\n <div class=\"content-card\" *ngFor=\"let content of section.contents\" cdkDrag>\n <div class=\"content\">{{content.value}}</div>\n <div class=\"content-placeholder\" *cdkDragPlaceholder></div>\n </div>\n </div>\n </mat-card>\n <div class=\"custom-placeholder\" *cdkDragPlaceholder></div>\n </div>\n</div>\n", styles: [".outline{padding:0 20px}.content{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.card,.content-card{margin:4px;cursor:pointer}.content-card:not(:last-child){border-bottom:1px dotted #aaa}.custom-placeholder{background:#ccc;border:dotted 3px #999;transition:transform .25s cubic-bezier(0,0,.2,1);min-height:60px}.content-placeholder{background:#ccc;border:dotted 3px #999;transition:transform .25s cubic-bezier(0,0,.2,1);min-height:30px}\n"] }]
37
- }], ctorParameters: function () { return [{ type: i1.EntryService }]; } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0bGluZS12aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9jb21wb25lbnRzL291dGxpbmUtdmlldy9vdXRsaW5lLXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvb3V0bGluZS12aWV3L291dGxpbmUtdmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFnQixNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBVXZELE1BQU0sT0FBTyxvQkFBb0I7SUFLN0IsWUFDWSxZQUEwQjtRQUExQixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUh0QyxTQUFJLEdBQUcsSUFBSSxDQUFDO0lBS1osQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsWUFBWSxDQUFDLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3ZELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVcsQ0FBQyxDQUFDO1FBQ1QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUN6QixNQUFNLElBQUksR0FBRyxDQUFDLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDOUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxZQUFZLEdBQUcsRUFBRSxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2xGLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxZQUFZLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsV0FBVyxDQUFDLENBQUMsRUFBRSxPQUFPO1FBQ2xCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDekIsTUFBTSxJQUFJLEdBQUcsQ0FBQyxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUMsYUFBYSxDQUFDO1FBQzlDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsWUFBWSxHQUFHLEVBQUUsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwRixLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDYixJQUFJLENBQUMsWUFBWSxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUQsQ0FBQzs7aUhBOUJRLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHdEQ1ZqQyxrOEJBaUJBOzJGRFBhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDSSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7RW50cnl9IGZyb20gJy4uLy4uL2RhdGEvZW50cnknO1xuaW1wb3J0IHtFbnRyeVNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2VudHJ5LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwcC1vdXRsaW5lLXZpZXcnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9vdXRsaW5lLXZpZXcuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL291dGxpbmUtdmlldy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE91dGxpbmVWaWV3Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIGVudHJ5OiBFbnRyeTtcbiAgICBNYXRoID0gTWF0aDtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGVudHJ5U2VydmljZTogRW50cnlTZXJ2aWNlXG4gICAgKSB7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuZW50cnlTZXJ2aWNlLmN1cnJlbnRseUVkaXRlZEVudHJ5LnN1YnNjcmliZSgoZW50cnkpID0+IHtcbiAgICAgICAgICAgIHRoaXMuZW50cnkgPSBlbnRyeTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgc2VjdGlvbkRyb3AoZSkge1xuICAgICAgICBjb25zdCBlbnRyeSA9IHRoaXMuZW50cnk7XG4gICAgICAgIGNvbnN0IGRpZmYgPSBlLmN1cnJlbnRJbmRleCAtIGUucHJldmlvdXNJbmRleDtcbiAgICAgICAgZW50cnkuc2VjdGlvbnNbZS5wcmV2aW91c0luZGV4XS5vcmRlciA9IGUuY3VycmVudEluZGV4ICogMTAgKyAoZGlmZiA+IDAgPyAxIDogLTEpO1xuICAgICAgICBlbnRyeS5zb3J0KCk7XG4gICAgICAgIHRoaXMuZW50cnlTZXJ2aWNlLmN1cnJlbnRseUVkaXRlZEVudHJ5Lm5leHQodGhpcy5lbnRyeSk7XG4gICAgfVxuXG4gICAgY29udGVudERyb3AoZSwgc2VjdGlvbikge1xuICAgICAgICBjb25zdCBlbnRyeSA9IHRoaXMuZW50cnk7XG4gICAgICAgIGNvbnN0IGRpZmYgPSBlLmN1cnJlbnRJbmRleCAtIGUucHJldmlvdXNJbmRleDtcbiAgICAgICAgc2VjdGlvbi5jb250ZW50c1tlLnByZXZpb3VzSW5kZXhdLm9yZGVyID0gZS5jdXJyZW50SW5kZXggKiAxMCArIChkaWZmID4gMCA/IDEgOiAtMSk7XG4gICAgICAgIGVudHJ5LnNvcnQoKTtcbiAgICAgICAgdGhpcy5lbnRyeVNlcnZpY2UuY3VycmVudGx5RWRpdGVkRW50cnkubmV4dCh0aGlzLmVudHJ5KTtcbiAgICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiZW50cnlcIiBjbGFzcz1cInNlY3Rpb24gb3V0bGluZVwiPlxuICAgIDxoMSAqbmdJZj1cImVudHJ5Py5zZWN0aW9ucz8ubGVuZ3RoID09PSAwXCI+T3V0bGluZSBWaWV3PC9oMT5cbiAgICA8ZGl2IGNka0Ryb3BMaXN0IGNsYXNzPVwic2VjdGlvbnNcIiAoY2RrRHJvcExpc3REcm9wcGVkKT1cInNlY3Rpb25Ecm9wKCRldmVudClcIj5cbiAgICAgICAgPG1hdC1jYXJkIGNsYXNzPVwiY2FyZFwiIGNka0RyYWcgKm5nRm9yPVwibGV0IHNlY3Rpb24gb2YgZW50cnkuc2VjdGlvbnNcIj5cbiAgICAgICAgICAgIDxoMz5TZWN0aW9uIHt7TWF0aC5jZWlsKHNlY3Rpb24ub3JkZXIgLyAxMCkgKyAxfX08L2gzPlxuICAgICAgICAgICAge3tzZWN0aW9uLnN1YmhlYWRpbmd9fVxuICAgICAgICAgICAgPGRpdiBjZGtEcm9wTGlzdCBjbGFzcz1cImNvbnRlbnRzXCIgKGNka0Ryb3BMaXN0RHJvcHBlZCk9XCJjb250ZW50RHJvcCgkZXZlbnQsIHNlY3Rpb24pXCI+XG4gICAgICAgICAgICAgICAgPGgzPkNvbnRlbnRzIGZvciB7e3NlY3Rpb24uc3ViaGVhZGluZ319PC9oMz5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29udGVudC1jYXJkXCIgKm5nRm9yPVwibGV0IGNvbnRlbnQgb2Ygc2VjdGlvbi5jb250ZW50c1wiIGNka0RyYWc+XG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb250ZW50XCI+e3tjb250ZW50LnZhbHVlfX08L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbnRlbnQtcGxhY2Vob2xkZXJcIiAqY2RrRHJhZ1BsYWNlaG9sZGVyPjwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvbWF0LWNhcmQ+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjdXN0b20tcGxhY2Vob2xkZXJcIiAqY2RrRHJhZ1BsYWNlaG9sZGVyPjwvZGl2PlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -1,3 +0,0 @@
1
- export class SchedulePublishDialogData {
2
- }
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZWR1bGUtcHVibGlzaC1kaWFsb2ctZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NjaGVkdWxlLXB1Ymxpc2gtZGlhbG9nL3NjaGVkdWxlLXB1Ymxpc2gtZGlhbG9nLWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLHlCQUF5QjtDQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBTY2hlZHVsZVB1Ymxpc2hEaWFsb2dEYXRhIHtcbn1cbiJdfQ==
@@ -1,33 +0,0 @@
1
- import { Component, Inject } from '@angular/core';
2
- import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/dialog";
5
- import * as i2 from "@angular/material/button";
6
- import * as i3 from "@angular/material/input";
7
- import * as i4 from "@angular/material/form-field";
8
- import * as i5 from "@angular/material/datepicker";
9
- import * as i6 from "ngx-material-timepicker";
10
- import * as i7 from "./schedule-publish-dialog-data";
11
- export class SchedulePublishDialogComponent {
12
- constructor(dialogRef, data) {
13
- this.dialogRef = dialogRef;
14
- this.data = data;
15
- }
16
- ngOnInit() {
17
- }
18
- onNoClick() {
19
- }
20
- onYesClick() {
21
- this.dialogRef.close('test');
22
- }
23
- }
24
- SchedulePublishDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SchedulePublishDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
25
- SchedulePublishDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SchedulePublishDialogComponent, selector: "lib-schedule-publish-dialog", ngImport: i0, template: "<h1 mat-dialog-title>Select a Date and Time to Schedule This Post</h1>\n<!--<mat-radio-group aria-label=\"Select an option\">-->\n<!-- <mat-radio-button class=\"option\" value=\"unpublished\">Unpublished</mat-radio-button>-->\n<!-- <mat-radio-button class=\"option\" value=\"published\">Published</mat-radio-button>-->\n<!--</mat-radio-group>-->\n<p>Date</p>\n<mat-form-field appearance=\"fill\">\n <mat-label>Choose a date</mat-label>\n <input matInput [matDatepicker]=\"picker\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>\n<p>Time</p>\n<input [ngxTimepicker]=\"timepicker\" readonly>\n<ngx-material-timepicker #timepicker></ngx-material-timepicker>\n<div mat-dialog-actions>\n <button mat-button (click)=\"onNoClick()\">Cancel</button>\n <button mat-button (click)=\"onYesClick()\" cdkFocusInitial>Schedule Publish</button>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i3.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: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i6.NgxMaterialTimepickerComponent, selector: "ngx-material-timepicker", inputs: ["ESC", "hoursOnly", "ngxMaterialTimepickerTheme", "format", "minutesGap", "cancelBtnTmpl", "editableHintTmpl", "confirmBtnTmpl", "enableKeyboardInput", "preventOverlayClick", "disableAnimation", "appendToInput", "defaultTime", "timepickerClass", "theme", "min", "max"], outputs: ["timeSet", "opened", "closed", "hourSelected", "timeChanged"] }, { kind: "directive", type: i6.TimepickerDirective, selector: "[ngxTimepicker]", inputs: ["format", "value", "min", "max", "ngxTimepicker", "disabled", "disableClick"] }] });
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SchedulePublishDialogComponent, decorators: [{
27
- type: Component,
28
- args: [{ selector: 'lib-schedule-publish-dialog', template: "<h1 mat-dialog-title>Select a Date and Time to Schedule This Post</h1>\n<!--<mat-radio-group aria-label=\"Select an option\">-->\n<!-- <mat-radio-button class=\"option\" value=\"unpublished\">Unpublished</mat-radio-button>-->\n<!-- <mat-radio-button class=\"option\" value=\"published\">Published</mat-radio-button>-->\n<!--</mat-radio-group>-->\n<p>Date</p>\n<mat-form-field appearance=\"fill\">\n <mat-label>Choose a date</mat-label>\n <input matInput [matDatepicker]=\"picker\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>\n<p>Time</p>\n<input [ngxTimepicker]=\"timepicker\" readonly>\n<ngx-material-timepicker #timepicker></ngx-material-timepicker>\n<div mat-dialog-actions>\n <button mat-button (click)=\"onNoClick()\">Cancel</button>\n <button mat-button (click)=\"onYesClick()\" cdkFocusInitial>Schedule Publish</button>\n</div>\n" }]
29
- }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: i7.SchedulePublishDialogData, decorators: [{
30
- type: Inject,
31
- args: [MAT_DIALOG_DATA]
32
- }] }]; } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZWR1bGUtcHVibGlzaC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc2NoZWR1bGUtcHVibGlzaC1kaWFsb2cvc2NoZWR1bGUtcHVibGlzaC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc2NoZWR1bGUtcHVibGlzaC1kaWFsb2cvc2NoZWR1bGUtcHVibGlzaC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFlLGVBQWUsRUFBQyxNQUFNLDBCQUEwQixDQUFDOzs7Ozs7Ozs7QUFRdkUsTUFBTSxPQUFPLDhCQUE4QjtJQUV2QyxZQUNXLFNBQXVELEVBQzlCLElBQStCO1FBRHhELGNBQVMsR0FBVCxTQUFTLENBQThDO1FBQzlCLFNBQUksR0FBSixJQUFJLENBQTJCO0lBQy9ELENBQUM7SUFFTCxRQUFRO0lBQ1IsQ0FBQztJQUVELFNBQVM7SUFDVCxDQUFDO0lBRUQsVUFBVTtRQUNOLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pDLENBQUM7OzJIQWZRLDhCQUE4Qiw4Q0FJM0IsZUFBZTsrR0FKbEIsOEJBQThCLG1FQ1QzQyx1N0JBbUJBOzJGRFZhLDhCQUE4QjtrQkFMMUMsU0FBUzsrQkFDSSw2QkFBNkI7OzBCQVFsQyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01hdERpYWxvZ1JlZiwgTUFUX0RJQUxPR19EQVRBfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHtTY2hlZHVsZVB1Ymxpc2hEaWFsb2dEYXRhfSBmcm9tICcuL3NjaGVkdWxlLXB1Ymxpc2gtZGlhbG9nLWRhdGEnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xpYi1zY2hlZHVsZS1wdWJsaXNoLWRpYWxvZycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NjaGVkdWxlLXB1Ymxpc2gtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zY2hlZHVsZS1wdWJsaXNoLWRpYWxvZy5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgU2NoZWR1bGVQdWJsaXNoRGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8U2NoZWR1bGVQdWJsaXNoRGlhbG9nQ29tcG9uZW50PixcbiAgICAgICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBTY2hlZHVsZVB1Ymxpc2hEaWFsb2dEYXRhLFxuICAgICkgeyB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB9XG5cbiAgICBvbk5vQ2xpY2soKTogdm9pZCB7XG4gICAgfVxuXG4gICAgb25ZZXNDbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoJ3Rlc3QnKTtcbiAgICB9XG59XG4iLCI8aDEgbWF0LWRpYWxvZy10aXRsZT5TZWxlY3QgYSBEYXRlIGFuZCBUaW1lIHRvIFNjaGVkdWxlIFRoaXMgUG9zdDwvaDE+XG48IS0tPG1hdC1yYWRpby1ncm91cCBhcmlhLWxhYmVsPVwiU2VsZWN0IGFuIG9wdGlvblwiPi0tPlxuPCEtLSAgICA8bWF0LXJhZGlvLWJ1dHRvbiBjbGFzcz1cIm9wdGlvblwiIHZhbHVlPVwidW5wdWJsaXNoZWRcIj5VbnB1Ymxpc2hlZDwvbWF0LXJhZGlvLWJ1dHRvbj4tLT5cbjwhLS0gICAgPG1hdC1yYWRpby1idXR0b24gY2xhc3M9XCJvcHRpb25cIiB2YWx1ZT1cInB1Ymxpc2hlZFwiPlB1Ymxpc2hlZDwvbWF0LXJhZGlvLWJ1dHRvbj4tLT5cbjwhLS08L21hdC1yYWRpby1ncm91cD4tLT5cbjxwPkRhdGU8L3A+XG48bWF0LWZvcm0tZmllbGQgYXBwZWFyYW5jZT1cImZpbGxcIj5cbiAgPG1hdC1sYWJlbD5DaG9vc2UgYSBkYXRlPC9tYXQtbGFiZWw+XG4gIDxpbnB1dCBtYXRJbnB1dCBbbWF0RGF0ZXBpY2tlcl09XCJwaWNrZXJcIj5cbiAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggW2Zvcl09XCJwaWNrZXJcIj48L21hdC1kYXRlcGlja2VyLXRvZ2dsZT5cbiAgPG1hdC1kYXRlcGlja2VyICNwaWNrZXI+PC9tYXQtZGF0ZXBpY2tlcj5cbjwvbWF0LWZvcm0tZmllbGQ+XG48cD5UaW1lPC9wPlxuPGlucHV0IFtuZ3hUaW1lcGlja2VyXT1cInRpbWVwaWNrZXJcIiByZWFkb25seT5cbjxuZ3gtbWF0ZXJpYWwtdGltZXBpY2tlciAjdGltZXBpY2tlcj48L25neC1tYXRlcmlhbC10aW1lcGlja2VyPlxuPGRpdiBtYXQtZGlhbG9nLWFjdGlvbnM+XG4gICAgPGJ1dHRvbiBtYXQtYnV0dG9uIChjbGljayk9XCJvbk5vQ2xpY2soKVwiPkNhbmNlbDwvYnV0dG9uPlxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiAoY2xpY2spPVwib25ZZXNDbGljaygpXCIgY2RrRm9jdXNJbml0aWFsPlNjaGVkdWxlIFB1Ymxpc2g8L2J1dHRvbj5cbjwvZGl2PlxuIl19
@@ -1,222 +0,0 @@
1
- import { Component, EventEmitter, ViewChild } from '@angular/core';
2
- import { trigger, state, style, animate, transition } from '@angular/animations';
3
- import { FormControl } from '@angular/forms';
4
- import { filter } from 'lodash';
5
- import { map } from 'lodash';
6
- import { debounceTime } from 'rxjs/operators';
7
- import { Entry } from '../../data/entry';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../../services/entry.service";
10
- import * as i2 from "@angular/router";
11
- import * as i3 from "../../services/identity.service";
12
- import * as i4 from "@angular/common";
13
- import * as i5 from "@angular/forms";
14
- import * as i6 from "@angular/material/input";
15
- import * as i7 from "@angular/material/form-field";
16
- import * as i8 from "@angular/material/list";
17
- export class SideNavigationComponent {
18
- constructor(entryService, router, identityService, renderer) {
19
- this.entryService = entryService;
20
- this.router = router;
21
- this.identityService = identityService;
22
- this.renderer = renderer;
23
- this.state = 'out';
24
- this.entries = [];
25
- this.entriesByMonthAndYear = [];
26
- this.searchTerm = "";
27
- this.doSearch = new EventEmitter();
28
- this.searchControl = new FormControl('');
29
- }
30
- ngOnInit() {
31
- this.doSearch.pipe(debounceTime(500)).subscribe((result) => {
32
- this.searchEntries(result);
33
- });
34
- this.identityService.getMe().subscribe((identity) => {
35
- this.identity = identity;
36
- }, (err) => {
37
- this.identity = null;
38
- });
39
- this.getEntries();
40
- }
41
- getEntriesWithUrl(url) {
42
- this.entryService.getListByUrl(url).subscribe((response) => {
43
- this.entries = this.entries.concat(map(response.results, (result) => {
44
- return { id: result.id, entry: new Entry(result) };
45
- }));
46
- if (response.next) {
47
- this.getEntriesWithUrl(response.next);
48
- }
49
- else {
50
- this.organizeEntries();
51
- }
52
- });
53
- }
54
- organizeEntries() {
55
- this.state = 'out';
56
- let organizeEntriesFn = () => {
57
- this.entriesByMonthAndYear = [];
58
- let newEntries = JSON.parse(JSON.stringify(this.entriesByMonthAndYear));
59
- for (const entryWrapper of this.entries) {
60
- const entry = entryWrapper.entry;
61
- const create_date = new Date(entry.create_date);
62
- const month = create_date.getMonth();
63
- const year = create_date.getFullYear();
64
- const key = month + '/' + year;
65
- const sort_index = (year * 100) + month;
66
- const containers = filter(newEntries, (entryContainer) => entryContainer.month_year === key);
67
- if (containers.length > 0) {
68
- const container = containers[0];
69
- const entriesWithId = filter(container.entries, (e) => e.id === entryWrapper.entry.id);
70
- if (entriesWithId.length === 0) {
71
- container.entries.push(entry);
72
- }
73
- }
74
- else {
75
- const newContainer = { month_year: key, month_year_number: sort_index, entries: [entry] };
76
- newEntries.push(newContainer);
77
- }
78
- }
79
- newEntries.sort((entry_a, entry_b) => {
80
- return entry_a.month_year_number - entry_b.month_year_number;
81
- });
82
- newEntries.reverse();
83
- let setEntriesFn = () => {
84
- this.entriesByMonthAndYear = newEntries;
85
- this.state = 'in';
86
- };
87
- setTimeout(setEntriesFn.bind(this), 400);
88
- };
89
- setTimeout(organizeEntriesFn.bind(this), 400);
90
- }
91
- getEntries() {
92
- this.entryService.get().subscribe((response) => {
93
- this.entries = map(response.results, (result) => {
94
- return { id: result.id, entry: new Entry(result) };
95
- });
96
- if (response.next) {
97
- this.getEntriesWithUrl(response.next);
98
- }
99
- else {
100
- this.organizeEntries();
101
- }
102
- });
103
- }
104
- searchEntries(searchTerm) {
105
- if (searchTerm !== "") {
106
- this.entryService.search(searchTerm).subscribe((response) => {
107
- this.entries = map(response.results, (result) => {
108
- return { id: result.id, entry: new Entry(result) };
109
- });
110
- if (response.next) {
111
- this.getEntriesWithUrl(response.next);
112
- }
113
- else {
114
- this.organizeEntries();
115
- }
116
- });
117
- }
118
- else {
119
- this.getEntries();
120
- }
121
- }
122
- render() {
123
- }
124
- routeTo(entry) {
125
- if (!entry) {
126
- this.router.navigateByUrl('create(left-col:create//right-col:create)').then(() => {
127
- });
128
- }
129
- else {
130
- this.router.navigate(['/', 'blog', entry.slug]).then(() => {
131
- // Noop
132
- });
133
- }
134
- }
135
- getMonthAndYearFromKey(key) {
136
- let subheading = '';
137
- const parts = key.split('/');
138
- switch (Number(parts[0])) {
139
- case 0:
140
- subheading += 'January ';
141
- break;
142
- case 1:
143
- subheading += 'February ';
144
- break;
145
- case 2:
146
- subheading += 'March ';
147
- break;
148
- case 3:
149
- subheading += 'April ';
150
- break;
151
- case 4:
152
- subheading += 'May ';
153
- break;
154
- case 5:
155
- subheading += 'June ';
156
- break;
157
- case 6:
158
- subheading += 'July ';
159
- break;
160
- case 7:
161
- subheading += 'August ';
162
- break;
163
- case 8:
164
- subheading += 'September ';
165
- break;
166
- case 9:
167
- subheading += 'October ';
168
- break;
169
- case 10:
170
- subheading += 'November ';
171
- break;
172
- case 11:
173
- subheading += 'December ';
174
- break;
175
- default:
176
- subheading += 'January ';
177
- }
178
- subheading += parts[1];
179
- return subheading;
180
- }
181
- ngOnDestroy() {
182
- if (this.sourceSub) {
183
- this.sourceSub.unsubscribe();
184
- this.sourceSub = null;
185
- }
186
- }
187
- onSearchChange(searchValue) {
188
- this.doSearch.emit(searchValue);
189
- }
190
- }
191
- 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: [
193
- trigger('sideNavAnimation', [
194
- state('in', style({ transform: 'translateX(0%)' })),
195
- state('out', style({ transform: 'translateX(110%)' })),
196
- transition('in => out', [
197
- animate('100ms ease-out', style({ transform: 'translateX(110%)' }))
198
- ]),
199
- transition('out => in', [
200
- animate('100ms ease-in', style({ transform: 'translateX(0%)' }))
201
- ])
202
- ]),
203
- ] });
204
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SideNavigationComponent, decorators: [{
205
- type: Component,
206
- args: [{ selector: 'app-side-navigation', animations: [
207
- trigger('sideNavAnimation', [
208
- state('in', style({ transform: 'translateX(0%)' })),
209
- state('out', style({ transform: 'translateX(110%)' })),
210
- transition('in => out', [
211
- animate('100ms ease-out', style({ transform: 'translateX(110%)' }))
212
- ]),
213
- transition('out => in', [
214
- animate('100ms ease-in', style({ transform: 'translateX(0%)' }))
215
- ])
216
- ]),
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"] }]
218
- }], ctorParameters: function () { return [{ type: i1.EntryService }, { type: i2.Router }, { type: i3.IdentityService }, { type: i0.Renderer2 }]; }, propDecorators: { divNav: [{
219
- type: ViewChild,
220
- args: ['navcontainer', { static: false }]
221
- }] } });
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"]}
@@ -1,28 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/static-html.service";
4
- import * as i2 from "@angular/platform-browser";
5
- export class StaticHtmlComponent {
6
- constructor(staticHtmlService, domSanitizer) {
7
- this.staticHtmlService = staticHtmlService;
8
- this.domSanitizer = domSanitizer;
9
- }
10
- refreshContent() {
11
- this.innerHtml = this.domSanitizer.bypassSecurityTrustHtml(this.staticHtmlService.mapStaticHtml(this.value, false));
12
- }
13
- ngOnChanges(changes) {
14
- this.refreshContent();
15
- }
16
- ngOnInit() {
17
- this.refreshContent();
18
- }
19
- }
20
- StaticHtmlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: StaticHtmlComponent, deps: [{ token: i1.StaticHtmlService }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
21
- StaticHtmlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: StaticHtmlComponent, selector: "app-static-html", inputs: { value: "value" }, usesOnChanges: true, ngImport: i0, template: "<div [innerHtml]=\"innerHtml\">\n</div>\n", styles: [""] });
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: StaticHtmlComponent, decorators: [{
23
- type: Component,
24
- args: [{ selector: 'app-static-html', template: "<div [innerHtml]=\"innerHtml\">\n</div>\n" }]
25
- }], ctorParameters: function () { return [{ type: i1.StaticHtmlService }, { type: i2.DomSanitizer }]; }, propDecorators: { value: [{
26
- type: Input
27
- }] } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljLWh0bWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RhdGljLWh0bWwvc3RhdGljLWh0bWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RhdGljLWh0bWwvc3RhdGljLWh0bWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDOzs7O0FBU25GLE1BQU0sT0FBTyxtQkFBbUI7SUFLNUIsWUFDWSxpQkFBb0MsRUFDcEMsWUFBMEI7UUFEMUIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUNwQyxpQkFBWSxHQUFaLFlBQVksQ0FBYztJQUNsQyxDQUFDO0lBRUwsY0FBYztRQUNWLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUN4SCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQzlCLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUMxQixDQUFDOztnSEFwQlEsbUJBQW1CO29HQUFuQixtQkFBbUIsd0dDVGhDLDJDQUVBOzJGRE9hLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDSSxpQkFBaUI7bUlBT2xCLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgT25Jbml0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0RvbVNhbml0aXplciwgU2FmZUh0bWx9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHtTdGF0aWNIdG1sU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMvc3RhdGljLWh0bWwuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYXBwLXN0YXRpYy1odG1sJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc3RhdGljLWh0bWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3N0YXRpYy1odG1sLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBTdGF0aWNIdG1sQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuXG4gICAgaW5uZXJIdG1sOiBTYWZlSHRtbDtcbiAgICBASW5wdXQoKSB2YWx1ZTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHN0YXRpY0h0bWxTZXJ2aWNlOiBTdGF0aWNIdG1sU2VydmljZSxcbiAgICAgICAgcHJpdmF0ZSBkb21TYW5pdGl6ZXI6IERvbVNhbml0aXplclxuICAgICkgeyB9XG5cbiAgICByZWZyZXNoQ29udGVudCgpIHtcbiAgICAgICAgdGhpcy5pbm5lckh0bWwgPSB0aGlzLmRvbVNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbCh0aGlzLnN0YXRpY0h0bWxTZXJ2aWNlLm1hcFN0YXRpY0h0bWwodGhpcy52YWx1ZSwgZmFsc2UpKTtcbiAgICB9XG5cbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgICAgIHRoaXMucmVmcmVzaENvbnRlbnQoKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZWZyZXNoQ29udGVudCgpO1xuICAgIH1cblxufVxuIiwiPGRpdiBbaW5uZXJIdG1sXT1cImlubmVySHRtbFwiPlxuPC9kaXY+XG4iXX0=