@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.
@@ -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 = 'doc name';
10
+ this.documentName = '';
11
11
  this.quillConfig = {
12
- toolbar: [
13
- [{ header: '1' }, { header: '2' }, { font: [] }],
14
- [{ list: 'ordered' }, { list: 'bullet' }],
15
- ['bold', 'italic', 'underline'],
16
- ['link'],
17
- ['clean'],
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
- console.log("On Editor changed call");
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\">Save</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\r\n</div>",
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}"]}