@hivegpt/hiveai-angular 0.0.283 → 0.0.287
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/bundles/hivegpt-hiveai-angular.umd.js +43 -13
- package/bundles/hivegpt-hiveai-angular.umd.js.map +1 -1
- package/bundles/hivegpt-hiveai-angular.umd.min.js +1 -1
- package/bundles/hivegpt-hiveai-angular.umd.min.js.map +1 -1
- package/esm2015/lib/components/bot-html-editor/bot-html-editor.component.js +41 -12
- package/esm2015/lib/components/chat-drawer/chat-drawer.component.js +3 -3
- package/fesm2015/hivegpt-hiveai-angular.js +42 -13
- package/fesm2015/hivegpt-hiveai-angular.js.map +1 -1
- package/hivegpt-hiveai-angular.metadata.json +1 -1
- package/lib/components/bot-html-editor/bot-html-editor.component.d.ts +27 -12
- package/lib/components/bot-html-editor/bot-html-editor.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -7,16 +7,32 @@ export class BotHtmlEditorComponent {
|
|
|
7
7
|
constructor(cdr, http) {
|
|
8
8
|
this.cdr = cdr;
|
|
9
9
|
this.http = http;
|
|
10
|
-
this.documentName = '
|
|
10
|
+
this.documentName = '';
|
|
11
11
|
this.quillConfig = {
|
|
12
|
-
toolbar:
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
12
|
+
toolbar: {
|
|
13
|
+
container: [
|
|
14
|
+
[{ header: '1' }, { header: '2' }, { font: [] }],
|
|
15
|
+
[{ list: 'ordered' }, { list: 'bullet' }],
|
|
16
|
+
['bold', 'italic', 'underline'],
|
|
17
|
+
['link'],
|
|
18
|
+
['clean'],
|
|
19
|
+
['undo', 'redo'],
|
|
20
|
+
],
|
|
21
|
+
handlers: {
|
|
22
|
+
undo: () => this.quillEditor.history.undo(),
|
|
23
|
+
redo: () => this.quillEditor.history.redo(),
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
history: {
|
|
27
|
+
delay: 1000,
|
|
28
|
+
maxStack: 100,
|
|
29
|
+
userOnly: true,
|
|
30
|
+
},
|
|
19
31
|
};
|
|
32
|
+
this.isShowSaved = true;
|
|
33
|
+
}
|
|
34
|
+
onEditorCreated(editorInstance) {
|
|
35
|
+
this.quillEditor = editorInstance;
|
|
20
36
|
}
|
|
21
37
|
ngOnInit() {
|
|
22
38
|
this.environment = prod_environment;
|
|
@@ -30,6 +46,15 @@ export class BotHtmlEditorComponent {
|
|
|
30
46
|
}
|
|
31
47
|
}, 2500);
|
|
32
48
|
}
|
|
49
|
+
ngOnChanges(changes) {
|
|
50
|
+
var _a, _b;
|
|
51
|
+
if (changes.editorContent) {
|
|
52
|
+
if (this.documentContent && ((_a = this.documentContent) === null || _a === void 0 ? void 0 : _a.content)) {
|
|
53
|
+
this.editorContent =
|
|
54
|
+
((_b = this.documentContent) === null || _b === void 0 ? void 0 : _b.content) + '<br />' + this.editorContent;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
33
58
|
filldataInForm() {
|
|
34
59
|
var _a, _b;
|
|
35
60
|
if (this.documentContent) {
|
|
@@ -58,12 +83,14 @@ export class BotHtmlEditorComponent {
|
|
|
58
83
|
content: this.editorContent,
|
|
59
84
|
};
|
|
60
85
|
return this.http.post(url, data, { headers }).pipe(switchMap((res) => {
|
|
86
|
+
this.isShowSaved = true;
|
|
61
87
|
if (res) {
|
|
62
88
|
// alert('Saved Successfully');
|
|
63
89
|
}
|
|
64
90
|
this.cdr.markForCheck();
|
|
65
91
|
return of(res);
|
|
66
92
|
}), catchError((error) => {
|
|
93
|
+
this.isShowSaved = true;
|
|
67
94
|
console.error('Error fetching chatbot config: ', error);
|
|
68
95
|
return of(null);
|
|
69
96
|
}));
|
|
@@ -80,19 +107,21 @@ export class BotHtmlEditorComponent {
|
|
|
80
107
|
content: this.editorContent,
|
|
81
108
|
};
|
|
82
109
|
return this.http.put(url, data, { headers }).pipe(switchMap((res) => {
|
|
110
|
+
this.isShowSaved = true;
|
|
83
111
|
if (res) {
|
|
84
112
|
// alert('Updated Successfully');
|
|
85
113
|
}
|
|
86
114
|
this.cdr.markForCheck();
|
|
87
115
|
return of(res);
|
|
88
116
|
}), catchError((error) => {
|
|
117
|
+
this.isShowSaved = true;
|
|
89
118
|
console.error('Error fetching chatbot config: ', error);
|
|
90
119
|
return of(null);
|
|
91
120
|
}));
|
|
92
121
|
}
|
|
93
122
|
// Function that gets called on editor content change
|
|
94
123
|
onEditorContentChanged(event) {
|
|
95
|
-
|
|
124
|
+
this.isShowSaved = false;
|
|
96
125
|
// Clear the previous timeout if the function is called again before the delay
|
|
97
126
|
if (this.timeout) {
|
|
98
127
|
clearTimeout(this.timeout);
|
|
@@ -104,14 +133,14 @@ export class BotHtmlEditorComponent {
|
|
|
104
133
|
}
|
|
105
134
|
// Function to be called after delay
|
|
106
135
|
handleEditorChange() {
|
|
136
|
+
console.log('Editor content changed after delay:', this.editorContent);
|
|
107
137
|
this.saveContent();
|
|
108
|
-
// Add your function logic here
|
|
109
138
|
}
|
|
110
139
|
}
|
|
111
140
|
BotHtmlEditorComponent.decorators = [
|
|
112
141
|
{ type: Component, args: [{
|
|
113
142
|
selector: 'lib-bot-html-editor',
|
|
114
|
-
template: "<div style=\"padding: 12px\">\r\n <div style=\"margin-top: 42px\" class=\"form-group\">\r\n <input [(ngModel)]=\"documentName\" class=\"form-control\" type=\"text\" />\r\n <button (click)=\"saveContent()\" class=\"save-btn\">
|
|
143
|
+
template: "<div style=\"padding: 12px\">\r\n <div style=\"margin-top: 42px\" class=\"form-group\">\r\n <input [(ngModel)]=\"documentName\" (blur)=\"saveContent()\" class=\"form-control\" placeholder=\"Type document name...\"\r\n type=\"text\" />\r\n <button *ngIf=\"isShowSaved\" (click)=\"saveContent()\" class=\"save-btn\">\r\n Saved\r\n </button>\r\n\r\n <button *ngIf=\"!isShowSaved\" class=\"save-btn\">Unsaved</button>\r\n </div>\r\n\r\n <quill-editor [(ngModel)]=\"editorContent\" [modules]=\"quillConfig\" (onContentChanged)=\"onEditorContentChanged($event)\"\r\n placeholder=\"Start typing or paste to get started...\"></quill-editor>\r\n</div>",
|
|
115
144
|
styles: [".save-btn{background-color:#f0f0f0;border:none;color:#333;margin-top:22px;position:absolute;right:16px;width:56px}"]
|
|
116
145
|
},] }
|
|
117
146
|
];
|
|
@@ -126,4 +155,4 @@ BotHtmlEditorComponent.propDecorators = {
|
|
|
126
155
|
conversationId: [{ type: Input }],
|
|
127
156
|
botId: [{ type: Input }]
|
|
128
157
|
};
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bot-html-editor.component.js","sourceRoot":"D:/hiveGPT-AI-packages/HiveAI-Packages/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/bot-html-editor/bot-html-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { MatDrawer } from '@angular/material/sidenav';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { of, Subscription } from 'rxjs';\r\nimport { catchError, switchMap } from 'rxjs/operators';\r\nimport { formatNow, formatTimeStamps } from '../../utils/utils';\r\nimport {\r\n  dev_environment,\r\n  prod_environment,\r\n} from '../../../environments/environment';\r\nimport { ConversationService } from '../conversation.service';\r\nimport { Observable } from 'rxjs';\r\nimport { SocketService } from '../socket-service.service';\r\n\r\n@Component({\r\n  selector: 'lib-bot-html-editor',\r\n  templateUrl: './bot-html-editor.component.html',\r\n  styleUrls: ['./bot-html-editor.component.css'],\r\n})\r\nexport class BotHtmlEditorComponent implements OnInit {\r\n  @Input() editorContent: Observable<string>;\r\n  @Input() isDocInEditMode: any;\r\n  @Input() documentContent: any;\r\n  @Input() conversationId: any;\r\n  @Input() botId: any;\r\n\r\n  documentName: any = 'doc name';\r\n\r\n  environment: {\r\n    USERS_API;\r\n    BASE_URL;\r\n    AGENTS_API;\r\n  };\r\n\r\n  quillConfig = {\r\n    toolbar: [\r\n      [{ header: '1' }, { header: '2' }, { font: [] }],\r\n      [{ list: 'ordered' }, { list: 'bullet' }],\r\n      ['bold', 'italic', 'underline'],\r\n      ['link'],\r\n      ['clean'],\r\n    ],\r\n  };\r\n  constructor(private cdr: ChangeDetectorRef, private http: HttpClient) { }\r\n\r\n  ngOnInit(): void {\r\n    this.environment = prod_environment;\r\n\r\n    setTimeout(() => {\r\n      if (this.isDocInEditMode) {\r\n        console.log('In Edit mode');\r\n        this.filldataInForm();\r\n      } else {\r\n        console.log('In save mode');\r\n      }\r\n    }, 2500);\r\n  }\r\n\r\n  filldataInForm() {\r\n    if (this.documentContent) {\r\n      this.documentName = this.documentContent?.name;\r\n      this.editorContent = this.documentContent?.content;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  saveContent() {\r\n    if (!this.isDocInEditMode) {\r\n      this.saveContent_http().subscribe();\r\n    } else {\r\n      this.saveContent_http().subscribe();\r\n    }\r\n  }\r\n\r\n  saveContent_http() {\r\n    console.log('API call function');\r\n\r\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${this.conversationId}&botId=${this.botId}`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\r\n    });\r\n\r\n    let data = {\r\n      name: this.documentName,\r\n      content: this.editorContent,\r\n    };\r\n\r\n    return this.http.post(url, data, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        if (res) {\r\n          //  alert('Saved Successfully');\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        console.error('Error fetching chatbot config: ', error);\r\n\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  updateContent_http() {\r\n    console.log('API call function');\r\n\r\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments/rename?conversationId=${this.conversationId}&botId=${this.botId}`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\r\n    });\r\n\r\n    let data = {\r\n      name: this.documentName,\r\n      content: this.editorContent,\r\n    };\r\n\r\n    return this.http.put(url, data, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        if (res) {\r\n          // alert('Updated Successfully');\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        console.error('Error fetching chatbot config: ', error);\r\n\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n\r\n  private timeout: any;\r\n\r\n  // Function that gets called on editor content change\r\n\r\n  onEditorContentChanged(event: any) {\r\n\r\n    console.log(\"On Editor changed call\");\r\n\r\n    // Clear the previous timeout if the function is called again before the delay\r\n\r\n    if (this.timeout) {\r\n\r\n      clearTimeout(this.timeout);\r\n\r\n    }\r\n\r\n    // Set a new timeout for 2-3 seconds delay\r\n\r\n    this.timeout = setTimeout(() => {\r\n\r\n      this.handleEditorChange();\r\n\r\n    }, 2000); // 2000ms = 2 seconds (adjust to 3000 for 3 seconds)\r\n\r\n  }\r\n\r\n  // Function to be called after delay\r\n\r\n  handleEditorChange() {\r\n\r\n    this.saveContent();\r\n\r\n    // Add your function logic here\r\n\r\n  }\r\n}\r\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bot-html-editor.component.js","sourceRoot":"D:/hiveGPT-AI-packages/HiveAI-Packages/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/bot-html-editor/bot-html-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { MatDrawer } from '@angular/material/sidenav';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { of, Subscription } from 'rxjs';\r\nimport { catchError, switchMap } from 'rxjs/operators';\r\nimport { formatNow, formatTimeStamps } from '../../utils/utils';\r\nimport {\r\n  dev_environment,\r\n  prod_environment,\r\n} from '../../../environments/environment';\r\nimport { ConversationService } from '../conversation.service';\r\nimport { Observable } from 'rxjs';\r\nimport { SocketService } from '../socket-service.service';\r\n\r\n@Component({\r\n  selector: 'lib-bot-html-editor',\r\n  templateUrl: './bot-html-editor.component.html',\r\n  styleUrls: ['./bot-html-editor.component.css'],\r\n})\r\nexport class BotHtmlEditorComponent implements OnInit, OnChanges {\r\n  @Input() editorContent: any;\r\n  @Input() isDocInEditMode: any;\r\n  @Input() documentContent: any;\r\n  @Input() conversationId: any;\r\n  @Input() botId: any;\r\n\r\n  documentName: any = '';\r\n\r\n  environment: {\r\n    USERS_API;\r\n    BASE_URL;\r\n    AGENTS_API;\r\n  };\r\n\r\n  quillConfig = {\r\n    toolbar: {\r\n      container: [\r\n        [{ header: '1' }, { header: '2' }, { font: [] }],\r\n        [{ list: 'ordered' }, { list: 'bullet' }],\r\n        ['bold', 'italic', 'underline'],\r\n        ['link'],\r\n        ['clean'],\r\n        ['undo', 'redo'], // Add undo/redo buttons\r\n      ],\r\n      handlers: {\r\n        undo: () => this.quillEditor.history.undo(),\r\n        redo: () => this.quillEditor.history.redo(),\r\n      },\r\n    },\r\n    history: {\r\n      delay: 1000,\r\n      maxStack: 100,\r\n      userOnly: true,\r\n    },\r\n  };\r\n\r\n  quillEditor: any;\r\n\r\n  onEditorCreated(editorInstance: any) {\r\n    this.quillEditor = editorInstance;\r\n  }\r\n  constructor(private cdr: ChangeDetectorRef, private http: HttpClient) { }\r\n\r\n  ngOnInit(): void {\r\n    this.environment = prod_environment;\r\n\r\n    setTimeout(() => {\r\n      if (this.isDocInEditMode) {\r\n        console.log('In Edit mode');\r\n        this.filldataInForm();\r\n      } else {\r\n        console.log('In save mode');\r\n      }\r\n    }, 2500);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.editorContent) {\r\n      if (this.documentContent && this.documentContent?.content) {\r\n        this.editorContent =\r\n          this.documentContent?.content + '<br />' + this.editorContent;\r\n      }\r\n    }\r\n  }\r\n\r\n  filldataInForm() {\r\n    if (this.documentContent) {\r\n      this.documentName = this.documentContent?.name;\r\n      this.editorContent = this.documentContent?.content;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  isShowSaved = true;\r\n\r\n  saveContent() {\r\n    if (!this.isDocInEditMode) {\r\n      this.saveContent_http().subscribe();\r\n    } else {\r\n      this.saveContent_http().subscribe();\r\n    }\r\n  }\r\n\r\n  saveContent_http() {\r\n    console.log('API call function');\r\n\r\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments?conversationId=${this.conversationId}&botId=${this.botId}`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\r\n    });\r\n\r\n    let data = {\r\n      name: this.documentName,\r\n      content: this.editorContent,\r\n    };\r\n\r\n    return this.http.post(url, data, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        this.isShowSaved = true;\r\n        if (res) {\r\n          //  alert('Saved Successfully');\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        this.isShowSaved = true;\r\n        console.error('Error fetching chatbot config: ', error);\r\n\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  updateContent_http() {\r\n    console.log('API call function');\r\n\r\n    const url = `${this.environment.AGENTS_API}/ConversationDocuments/rename?conversationId=${this.conversationId}&botId=${this.botId}`;\r\n    const headers = new HttpHeaders({\r\n      'Content-Type': 'application/json',\r\n      apiKey: 'WIz/qAm+EEmfOkFaUA/weA==',\r\n    });\r\n\r\n    let data = {\r\n      name: this.documentName,\r\n      content: this.editorContent,\r\n    };\r\n\r\n    return this.http.put(url, data, { headers }).pipe(\r\n      switchMap((res: any) => {\r\n        this.isShowSaved = true;\r\n        if (res) {\r\n          // alert('Updated Successfully');\r\n        }\r\n        this.cdr.markForCheck();\r\n\r\n        return of(res);\r\n      }),\r\n      catchError((error) => {\r\n        this.isShowSaved = true;\r\n        console.error('Error fetching chatbot config: ', error);\r\n\r\n        return of(null);\r\n      })\r\n    );\r\n  }\r\n\r\n  private timeout: any;\r\n\r\n  // Function that gets called on editor content change\r\n  onEditorContentChanged(event: any) {\r\n    this.isShowSaved = false;\r\n    // Clear the previous timeout if the function is called again before the delay\r\n    if (this.timeout) {\r\n      clearTimeout(this.timeout);\r\n    }\r\n\r\n    // Set a new timeout for 2-3 seconds delay\r\n    this.timeout = setTimeout(() => {\r\n      this.handleEditorChange();\r\n    }, 2000); // 2000ms = 2 seconds (adjust to 3000 for 3 seconds)\r\n  }\r\n\r\n  // Function to be called after delay\r\n  handleEditorChange() {\r\n    console.log('Editor content changed after delay:', this.editorContent);\r\n    this.saveContent();\r\n  }\r\n}"]}
|