verben-ticketing-ui 0.6.0 → 0.8.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.
@@ -89,7 +89,7 @@ export class AddTicketComponent {
89
89
  if (options) {
90
90
  this.priorityOptions = options.Result;
91
91
  }
92
- console.log({ Changed: this.priorityOptions });
92
+ // console.log({ Changed: this.priorityOptions });
93
93
  }
94
94
  else if (changes['activeTenant'] && !this.activeTenant) {
95
95
  this.priorityOptions = [];
@@ -303,4 +303,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
303
303
  }], defaultCompany: [{
304
304
  type: Input
305
305
  }] } });
306
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-ticket.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-ticketing-ui/src/lib/components/add-ticket/add-ticket.component.ts","../../../../../../../projects/verben-ticketing-ui/src/lib/components/add-ticket/add-ticket.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { Application } from 'verben-ticketing-ui/src/lib/models';\nimport { Tenant } from 'verben-ticketing-ui/src/lib/models';\nimport { ErrorResponse } from 'verben-ticketing-ui/src/lib/models';\nimport { ObjectState } from 'verben-ticketing-ui/src/lib/models';\nimport { Ticket } from 'verben-ticketing-ui/src/lib/models';\nimport { TicketStatus } from 'verben-ticketing-ui/src/lib/models';\nimport {\n  UtilService as AppUtilService,\n  EnvironmentService,\n} from 'verben-ticketing-ui/src/lib/services';\nimport { HttpWebRequestService } from 'verben-ticketing-ui/src/lib/services';\n\nimport { TenantPriority } from 'verben-ticketing-ui/src/lib/models';\nimport { TicketMessage } from 'verben-ticketing-ui/src/lib/models';\nimport { DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD } from 'verben-ticketing-ui/src/lib/constants';\nimport { File } from 'verben-ticketing-ui/src/lib/models';\nimport { SharedService } from 'verben-ticketing-ui/src/lib/services';\n\n@Component({\n  selector: 'app-add-ticket',\n  templateUrl: './add-ticket.component.html',\n  styleUrl: './add-ticket.component.css',\n})\nexport class AddTicketComponent {\n  // test: string = '';\n  // logTest() {\n  //   console.log({ Test: this.test });\n  // }\n  createTicketForm: FormGroup;\n  @Input() activeApp: string | null = null;\n  @Input() activeTenant: string | null = null;\n  @Input() selectedTicket: Ticket | null = null;\n  @Input() isVisible: boolean = false;\n  @Output() onOpen: EventEmitter<Event> = new EventEmitter();\n  @Output() onClose: EventEmitter<Event> = new EventEmitter();\n  @Output() onSave: EventEmitter<Ticket> = new EventEmitter();\n\n  priorityOptions: TenantPriority[] = [];\n  statusOptions: string[] = Object.keys(TicketStatus);\n  fileData: File[] = [];\n  fileUrls: string[] = [];\n  //attachedMessage: TicketMessage | null = null;\n  maxFileSize = 15 * 1024 * 1024;\n  @Input() defaultCompany: string = '';\n\n  constructor(\n    private fb: FormBuilder,\n    private utilService: AppUtilService,\n    private server: HttpWebRequestService,\n    private sharedService: SharedService,\n    private envSvc: EnvironmentService,\n  ) {\n    this.createTicketForm = this.fb.group({\n      Title: new FormControl<string | null>(null, Validators.required),\n      Description: new FormControl<string | null>(null, Validators.required),\n      CurrentHandler: new FormControl<string | null>({\n        value: null,\n        disabled: true,\n      }),\n      LastHandler: new FormControl<string | null>({\n        value: null,\n        disabled: true,\n      }),\n      Priority: new FormControl<string | null>(null, Validators.required),\n      Status: new FormControl<TicketStatus>(\n        { value: TicketStatus.Pending, disabled: true },\n        Validators.required,\n      ),\n    });\n\n    // this.createTicketForm.controls['CurrentHandler'].disable();\n    // this.createTicketForm.controls['LastHandler'].disable();\n  }\n\n  ngOnInit(): void {}\n\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\n    if (changes['selectedTicket'] && this.selectedTicket) {\n      this.createTicketForm.patchValue({\n        Title: this.selectedTicket.Title,\n        Description: this.selectedTicket.Description,\n        CurrentHandler: this.selectedTicket.CurrentHandler,\n        LastHandler: this.selectedTicket.LastHandler,\n        Priority: this.selectedTicket.Priority,\n        Status: this.selectedTicket.Status,\n      });\n      this.fileUrls = [...this.selectedTicket.FileUrls];\n      this.fileData = [];\n    } else {\n      this.createTicketForm.patchValue({\n        Title: null,\n        Description: null,\n        CurrentHandler: null,\n        LastHandler: null,\n        Priority: null,\n        Status: TicketStatus.Pending,\n      });\n      this.fileUrls = [];\n      this.fileData = [];\n    }\n\n    if (changes['activeTenant'] && this.activeTenant) {\n      const options = await this.sharedService.getAllPrioritiesForTenant(\n        this.activeTenant,\n      );\n      if (options) {\n        this.priorityOptions = options.Result;\n      }\n      console.log({ Changed: this.priorityOptions });\n    } else if (changes['activeTenant'] && !this.activeTenant) {\n      this.priorityOptions = [];\n      // console.log({ Tenant: this.activeTenant, Reset: this.priorityOptions });\n    }\n  }\n\n  checkForm(): boolean {\n    if (this.createTicketForm.valid == true) {\n      return true;\n    }\n    return false;\n  }\n\n  onModalOpen(event: any) {\n    this.onOpen.emit();\n  }\n\n  onModalClose(event: any) {\n    this.onClose.emit(event);\n  }\n\n  // filterMessage(message: TicketMessage): TicketMessage {\n  //   return {\n  //     ...message,\n  //     AttachmentUrls: message.AttachmentUrls.filter(\n  //       (x) => x.split('/').length > 1\n  //     ),\n  //   };\n  // }\n\n  async save() {\n    if (!this.activeApp) {\n      return;\n    }\n    if (!this.activeTenant) {\n      return;\n    }\n    // if (this.selectedTicket && this.attachedMessage) {\n    //   if (idx > -1) {\n    //     this.selectedTicket.Messages[idx] = this.filterMessage(\n    //       this.attachedMessage\n    //     );\n    //   } else {\n    //     if (this.attachedMessage.Attachments.length > 0) {\n    //       this.selectedTicket.Messages.unshift(\n    //         this.filterMessage(this.attachedMessage)\n    //       );\n    //     }\n    //   }\n    // }\n\n    const item: Ticket = {\n      Title: this.createTicketForm.controls['Title'].value,\n      Description: this.createTicketForm.controls['Description'].value,\n      CurrentHandler: this.selectedTicket\n        ? this.selectedTicket.CurrentHandler\n        : undefined,\n      LastHandler: this.selectedTicket\n        ? this.selectedTicket.LastHandler\n        : undefined,\n      Priority: this.createTicketForm.controls['Priority'].value,\n      App: this.activeApp,\n      id: '',\n      Status: this.createTicketForm.controls['Status'].value,\n      Company: this.defaultCompany,\n      Messages: this.selectedTicket ? this.selectedTicket.Messages : [],\n      FileData: this.fileData,\n      FileUrls: this.selectedTicket ? this.selectedTicket.FileUrls : [],\n      Id: '',\n      ExecutionTime: this.selectedTicket\n        ? this.selectedTicket.ExecutionTime\n        : undefined,\n      Code: this.selectedTicket ? this.selectedTicket.Code : '',\n      TenantId: this.selectedTicket\n        ? this.selectedTicket.TenantId\n        : this.activeTenant,\n      ServiceName: this.selectedTicket ? this.selectedTicket.ServiceName : '',\n      CreatedAt: this.selectedTicket\n        ? this.selectedTicket.CreatedAt\n        : new Date(),\n      UpdatedAt: new Date(),\n      DataState: this.selectedTicket ? ObjectState.Changed : ObjectState.New,\n    };\n\n    if (item.Description.trim().length == 0) {\n      this.utilService.showInfo('Description cannot be empty');\n      return;\n    }\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `Ticket/SaveTicket`,\n      [item],\n      this.envSvc.environment.TicketingAPI,\n    );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n    } else {\n      this.utilService.showSuccess('Ticket saved successfully');\n      const result = res as Ticket[];\n      if (result.length > 0) {\n        var resultItem = result[0];\n        this.onSave.emit(resultItem);\n      }\n    }\n\n    this.onClose.emit();\n  }\n\n  generateSixDigitNumber(): number {\n    return Math.floor(100000 + Math.random() * 900000);\n  }\n\n  getTicketMessage(): TicketMessage {\n    if (this.selectedTicket) {\n      const initialMessage = this.selectedTicket.Messages.find(\n        (x) => x.Subject == DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n      );\n      if (initialMessage) {\n        return { ...initialMessage, DataState: ObjectState.Changed };\n      } else {\n        const newMessage: TicketMessage = {\n          TicketCode: '',\n          Subject: DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n          Content: '',\n          Attachments: [],\n          AttachmentUrls: [],\n          Company: this.defaultCompany,\n          Id: '',\n          Code: '',\n          TenantId: '',\n          id: '',\n          ServiceName: '',\n          CreatedAt: new Date(),\n          UpdatedAt: new Date(),\n          DataState: ObjectState.New,\n        };\n        return newMessage;\n      }\n    } else {\n      const newMessage: TicketMessage = {\n        TicketCode: '',\n        Subject: DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n        Content: '',\n        Attachments: [],\n        AttachmentUrls: [],\n        Company: this.defaultCompany,\n        Id: '',\n        id: '',\n        Code: '',\n        TenantId: '',\n        ServiceName: '',\n        CreatedAt: new Date(),\n        UpdatedAt: new Date(),\n        DataState: ObjectState.New,\n      };\n      return newMessage;\n    }\n  }\n\n  triggerFileUpload(): void {\n    const fileInput: HTMLInputElement = document.createElement('input');\n    fileInput.type = 'file';\n    fileInput.accept = '.png, .jpg, .jpeg, .pdf';\n    fileInput.style.display = 'none'; // Hidden file input\n    document.body.appendChild(fileInput); // Temporarily add to DOM\n\n    fileInput.addEventListener('change', () => {\n      const file = fileInput.files?.[0];\n      if (file) {\n        this.processFile(file);\n      }\n      document.body.removeChild(fileInput); // Clean up after use\n    });\n\n    fileInput.click(); // Programmatically trigger click\n  }\n\n  private async processFile(selectedFile: globalThis.File): Promise<void> {\n    // Check file size\n    if (selectedFile.size > this.maxFileSize) {\n      const limitInMB = this.maxFileSize / 1024 / 1024;\n      this.utilService.showInfo(`File size limit of ${limitInMB}mb exceeded`);\n      return;\n    }\n\n    // let fileToProcess: globalThis.File | null = selectedFile;\n    // const safeNumber: number = 1 * 1024 * 1024;\n    // if (fileToProcess.size > safeNumber) {\n    //   fileToProcess = await this.utilService.compressImage(selectedFile);\n    //   if (!fileToProcess) {\n    //     this.utilService.showError('Error compressing image');\n    //     return;\n    //   }\n    // }\n\n    // Read file and convert to base64\n    const reader = new FileReader();\n    reader.readAsDataURL(selectedFile);\n    reader.onload = () => {\n      const base64data = reader.result as string;\n      const file = this.sharedService.createCustomFile(\n        base64data,\n        0,\n        selectedFile,\n      );\n      if (file) {\n        this.fileData.push(file);\n        this.fileUrls.push(`${file.Name}`);\n        // this.profileImage = base64data;\n      }\n    };\n  }\n}\n","<verben-dialogue\n  [showCloseIcon]=\"false\"\n  [dismissOutsideClick]=\"false\"\n  [closeOnEscape]=\"true\"\n  [size]=\"'medium'\"\n  [mode]=\"'dialogue'\"\n  [customClass]=\"'ticket-dialog'\"\n  [disableFooter]=\"true\"\n  (openModal)=\"onModalOpen($event)\"\n  [isVisible]=\"isVisible\"\n  [bodyTemplate]=\"bodyTemplate\"\n  (closeModal)=\"onModalClose($event)\"\n>\n  <ng-template #bodyTemplate>\n    <div class=\"dialog-body p-[25px] flex flex-col gap-4\">\n      <div class=\"dialog-header flex flex-col gap-1\">\n        <div class=\"dialog-title font-bold text-xl\">\n          {{ this.selectedTicket ? \"Edit Ticket\" : \"Create Ticket\" }}\n        </div>\n        <div class=\"dialog-subtitle\">\n          {{\n            this.selectedTicket\n              ? \"Fill the form below to edit selected ticket\"\n              : \"Fill the form below to create a ticket\"\n          }}\n        </div>\n      </div>\n      <!-- <verbena-textarea name=\"Test\" [(ngModel)]=\"test\" />\n      <button (click)=\"logTest()\">Log</button> -->\n      <div\n        [formGroup]=\"createTicketForm\"\n        class=\"add-app-form main-form-container flex flex-col gap-2\"\n      >\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Title</div>\n          <verbena-input\n            name=\"Title\"\n            placeHolder=\"Title\"\n            formControlName=\"Title\"\n          />\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Description</div>\n          <verbena-input name=\"Description\" formControlName=\"Description\" />\n        </div>\n        <div\n          *ngIf=\"this.selectedTicket\"\n          class=\"form-input-container flex flex-col gap-1\"\n        >\n          <div class=\"font-medium\">Current Handler</div>\n          <verbena-input\n            name=\"CurrentHandler\"\n            placeHolder=\"Current Handler\"\n            formControlName=\"CurrentHandler\"\n          />\n        </div>\n        <div\n          *ngIf=\"this.selectedTicket\"\n          class=\"form-input-container flex flex-col gap-1\"\n        >\n          <div class=\"font-medium\">Last Handler</div>\n          <verbena-input\n            name=\"LastHandler\"\n            placeHolder=\"Last Handler\"\n            formControlName=\"LastHandler\"\n          />\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Priority</div>\n          <verben-drop-down\n            width=\"100%\"\n            name=\"Priority\"\n            placeholder=\"Select Priority\"\n            [options]=\"priorityOptions\"\n            optionLabel=\"Name\"\n            optionValue=\"Code\"\n            formControlName=\"Priority\"\n          >\n          </verben-drop-down>\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Status</div>\n          <verben-drop-down\n            width=\"100%\"\n            name=\"Status\"\n            [disabled]=\"true\"\n            placeholder=\"Select Status\"\n            [options]=\"statusOptions\"\n            formControlName=\"Status\"\n          >\n          </verben-drop-down>\n        </div>\n        <div class=\"attachment-section p-2 flex flex-col gap-3\">\n          <div class=\"attachments-container grid grid-cols-3 gap-2\">\n            <ng-container *ngFor=\"let file of this.fileUrls\">\n              <app-file-render [fileUrl]=\"file\"></app-file-render>\n            </ng-container>\n          </div>\n          <div\n            class=\"upload-section flex flex-col flex-1 items-center justify-center gap-2\"\n          >\n            <div class=\"flex justify-center\">\n              <verbena-button\n                [useIcon]=\"true\"\n                [icon]=\"'upload'\"\n                class=\"verben-secondary-button\"\n                [text]=\"'Upload'\"\n                (click)=\"triggerFileUpload()\"\n              ></verbena-button>\n            </div>\n            <div class=\"upload-caption text-sm text-center\">\n              Include Attachments\n            </div>\n          </div>\n        </div>\n      </div>\n      <div class=\"dialog-button-container flex justify-end gap-2\">\n        <verbena-button\n          width=\"100%\"\n          class=\"verben-secondary-button\"\n          [text]=\"'Close'\"\n          (click)=\"onModalClose($event)\"\n        >\n        </verbena-button>\n        <verbena-button\n          [disable]=\"!this.checkForm()\"\n          width=\"100%\"\n          class=\"verben-primary-button\"\n          [text]=\"'Save'\"\n          (click)=\"save()\"\n        >\n        </verbena-button>\n      </div>\n    </div>\n  </ng-template>\n</verben-dialogue>\n"]}
306
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-ticket.component.js","sourceRoot":"","sources":["../../../../../../../projects/verben-ticketing-ui/src/lib/components/add-ticket/add-ticket.component.ts","../../../../../../../projects/verben-ticketing-ui/src/lib/components/add-ticket/add-ticket.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { Application } from 'verben-ticketing-ui/src/lib/models';\nimport { Tenant } from 'verben-ticketing-ui/src/lib/models';\nimport { ErrorResponse } from 'verben-ticketing-ui/src/lib/models';\nimport { ObjectState } from 'verben-ticketing-ui/src/lib/models';\nimport { Ticket } from 'verben-ticketing-ui/src/lib/models';\nimport { TicketStatus } from 'verben-ticketing-ui/src/lib/models';\nimport {\n  UtilService as AppUtilService,\n  EnvironmentService,\n} from 'verben-ticketing-ui/src/lib/services';\nimport { HttpWebRequestService } from 'verben-ticketing-ui/src/lib/services';\n\nimport { TenantPriority } from 'verben-ticketing-ui/src/lib/models';\nimport { TicketMessage } from 'verben-ticketing-ui/src/lib/models';\nimport { DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD } from 'verben-ticketing-ui/src/lib/constants';\nimport { File } from 'verben-ticketing-ui/src/lib/models';\nimport { SharedService } from 'verben-ticketing-ui/src/lib/services';\n\n@Component({\n  selector: 'app-add-ticket',\n  templateUrl: './add-ticket.component.html',\n  styleUrl: './add-ticket.component.css',\n})\nexport class AddTicketComponent {\n  // test: string = '';\n  // logTest() {\n  //   console.log({ Test: this.test });\n  // }\n  createTicketForm: FormGroup;\n  @Input() activeApp: string | null = null;\n  @Input() activeTenant: string | null = null;\n  @Input() selectedTicket: Ticket | null = null;\n  @Input() isVisible: boolean = false;\n  @Output() onOpen: EventEmitter<Event> = new EventEmitter();\n  @Output() onClose: EventEmitter<Event> = new EventEmitter();\n  @Output() onSave: EventEmitter<Ticket> = new EventEmitter();\n\n  priorityOptions: TenantPriority[] = [];\n  statusOptions: string[] = Object.keys(TicketStatus);\n  fileData: File[] = [];\n  fileUrls: string[] = [];\n  //attachedMessage: TicketMessage | null = null;\n  maxFileSize = 15 * 1024 * 1024;\n  @Input() defaultCompany: string = '';\n\n  constructor(\n    private fb: FormBuilder,\n    private utilService: AppUtilService,\n    private server: HttpWebRequestService,\n    private sharedService: SharedService,\n    private envSvc: EnvironmentService,\n  ) {\n    this.createTicketForm = this.fb.group({\n      Title: new FormControl<string | null>(null, Validators.required),\n      Description: new FormControl<string | null>(null, Validators.required),\n      CurrentHandler: new FormControl<string | null>({\n        value: null,\n        disabled: true,\n      }),\n      LastHandler: new FormControl<string | null>({\n        value: null,\n        disabled: true,\n      }),\n      Priority: new FormControl<string | null>(null, Validators.required),\n      Status: new FormControl<TicketStatus>(\n        { value: TicketStatus.Pending, disabled: true },\n        Validators.required,\n      ),\n    });\n\n    // this.createTicketForm.controls['CurrentHandler'].disable();\n    // this.createTicketForm.controls['LastHandler'].disable();\n  }\n\n  ngOnInit(): void {}\n\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\n    if (changes['selectedTicket'] && this.selectedTicket) {\n      this.createTicketForm.patchValue({\n        Title: this.selectedTicket.Title,\n        Description: this.selectedTicket.Description,\n        CurrentHandler: this.selectedTicket.CurrentHandler,\n        LastHandler: this.selectedTicket.LastHandler,\n        Priority: this.selectedTicket.Priority,\n        Status: this.selectedTicket.Status,\n      });\n      this.fileUrls = [...this.selectedTicket.FileUrls];\n      this.fileData = [];\n    } else {\n      this.createTicketForm.patchValue({\n        Title: null,\n        Description: null,\n        CurrentHandler: null,\n        LastHandler: null,\n        Priority: null,\n        Status: TicketStatus.Pending,\n      });\n      this.fileUrls = [];\n      this.fileData = [];\n    }\n\n    if (changes['activeTenant'] && this.activeTenant) {\n      const options = await this.sharedService.getAllPrioritiesForTenant(\n        this.activeTenant,\n      );\n      if (options) {\n        this.priorityOptions = options.Result;\n      }\n      //  console.log({ Changed: this.priorityOptions });\n    } else if (changes['activeTenant'] && !this.activeTenant) {\n      this.priorityOptions = [];\n      // console.log({ Tenant: this.activeTenant, Reset: this.priorityOptions });\n    }\n  }\n\n  checkForm(): boolean {\n    if (this.createTicketForm.valid == true) {\n      return true;\n    }\n    return false;\n  }\n\n  onModalOpen(event: any) {\n    this.onOpen.emit();\n  }\n\n  onModalClose(event: any) {\n    this.onClose.emit(event);\n  }\n\n  // filterMessage(message: TicketMessage): TicketMessage {\n  //   return {\n  //     ...message,\n  //     AttachmentUrls: message.AttachmentUrls.filter(\n  //       (x) => x.split('/').length > 1\n  //     ),\n  //   };\n  // }\n\n  async save() {\n    if (!this.activeApp) {\n      return;\n    }\n    if (!this.activeTenant) {\n      return;\n    }\n    // if (this.selectedTicket && this.attachedMessage) {\n    //   if (idx > -1) {\n    //     this.selectedTicket.Messages[idx] = this.filterMessage(\n    //       this.attachedMessage\n    //     );\n    //   } else {\n    //     if (this.attachedMessage.Attachments.length > 0) {\n    //       this.selectedTicket.Messages.unshift(\n    //         this.filterMessage(this.attachedMessage)\n    //       );\n    //     }\n    //   }\n    // }\n\n    const item: Ticket = {\n      Title: this.createTicketForm.controls['Title'].value,\n      Description: this.createTicketForm.controls['Description'].value,\n      CurrentHandler: this.selectedTicket\n        ? this.selectedTicket.CurrentHandler\n        : undefined,\n      LastHandler: this.selectedTicket\n        ? this.selectedTicket.LastHandler\n        : undefined,\n      Priority: this.createTicketForm.controls['Priority'].value,\n      App: this.activeApp,\n      id: '',\n      Status: this.createTicketForm.controls['Status'].value,\n      Company: this.defaultCompany,\n      Messages: this.selectedTicket ? this.selectedTicket.Messages : [],\n      FileData: this.fileData,\n      FileUrls: this.selectedTicket ? this.selectedTicket.FileUrls : [],\n      Id: '',\n      ExecutionTime: this.selectedTicket\n        ? this.selectedTicket.ExecutionTime\n        : undefined,\n      Code: this.selectedTicket ? this.selectedTicket.Code : '',\n      TenantId: this.selectedTicket\n        ? this.selectedTicket.TenantId\n        : this.activeTenant,\n      ServiceName: this.selectedTicket ? this.selectedTicket.ServiceName : '',\n      CreatedAt: this.selectedTicket\n        ? this.selectedTicket.CreatedAt\n        : new Date(),\n      UpdatedAt: new Date(),\n      DataState: this.selectedTicket ? ObjectState.Changed : ObjectState.New,\n    };\n\n    if (item.Description.trim().length == 0) {\n      this.utilService.showInfo('Description cannot be empty');\n      return;\n    }\n    this.utilService.sendBI(true);\n    const res = await this.server.post(\n      `Ticket/SaveTicket`,\n      [item],\n      this.envSvc.environment.TicketingAPI,\n    );\n    this.utilService.sendBI(false);\n    if (res instanceof ErrorResponse) {\n    } else {\n      this.utilService.showSuccess('Ticket saved successfully');\n      const result = res as Ticket[];\n      if (result.length > 0) {\n        var resultItem = result[0];\n        this.onSave.emit(resultItem);\n      }\n    }\n\n    this.onClose.emit();\n  }\n\n  generateSixDigitNumber(): number {\n    return Math.floor(100000 + Math.random() * 900000);\n  }\n\n  getTicketMessage(): TicketMessage {\n    if (this.selectedTicket) {\n      const initialMessage = this.selectedTicket.Messages.find(\n        (x) => x.Subject == DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n      );\n      if (initialMessage) {\n        return { ...initialMessage, DataState: ObjectState.Changed };\n      } else {\n        const newMessage: TicketMessage = {\n          TicketCode: '',\n          Subject: DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n          Content: '',\n          Attachments: [],\n          AttachmentUrls: [],\n          Company: this.defaultCompany,\n          Id: '',\n          Code: '',\n          TenantId: '',\n          id: '',\n          ServiceName: '',\n          CreatedAt: new Date(),\n          UpdatedAt: new Date(),\n          DataState: ObjectState.New,\n        };\n        return newMessage;\n      }\n    } else {\n      const newMessage: TicketMessage = {\n        TicketCode: '',\n        Subject: DEFAULT_MESSAGE_FOR_INITIAL_UPLOAD,\n        Content: '',\n        Attachments: [],\n        AttachmentUrls: [],\n        Company: this.defaultCompany,\n        Id: '',\n        id: '',\n        Code: '',\n        TenantId: '',\n        ServiceName: '',\n        CreatedAt: new Date(),\n        UpdatedAt: new Date(),\n        DataState: ObjectState.New,\n      };\n      return newMessage;\n    }\n  }\n\n  triggerFileUpload(): void {\n    const fileInput: HTMLInputElement = document.createElement('input');\n    fileInput.type = 'file';\n    fileInput.accept = '.png, .jpg, .jpeg, .pdf';\n    fileInput.style.display = 'none'; // Hidden file input\n    document.body.appendChild(fileInput); // Temporarily add to DOM\n\n    fileInput.addEventListener('change', () => {\n      const file = fileInput.files?.[0];\n      if (file) {\n        this.processFile(file);\n      }\n      document.body.removeChild(fileInput); // Clean up after use\n    });\n\n    fileInput.click(); // Programmatically trigger click\n  }\n\n  private async processFile(selectedFile: globalThis.File): Promise<void> {\n    // Check file size\n    if (selectedFile.size > this.maxFileSize) {\n      const limitInMB = this.maxFileSize / 1024 / 1024;\n      this.utilService.showInfo(`File size limit of ${limitInMB}mb exceeded`);\n      return;\n    }\n\n    // let fileToProcess: globalThis.File | null = selectedFile;\n    // const safeNumber: number = 1 * 1024 * 1024;\n    // if (fileToProcess.size > safeNumber) {\n    //   fileToProcess = await this.utilService.compressImage(selectedFile);\n    //   if (!fileToProcess) {\n    //     this.utilService.showError('Error compressing image');\n    //     return;\n    //   }\n    // }\n\n    // Read file and convert to base64\n    const reader = new FileReader();\n    reader.readAsDataURL(selectedFile);\n    reader.onload = () => {\n      const base64data = reader.result as string;\n      const file = this.sharedService.createCustomFile(\n        base64data,\n        0,\n        selectedFile,\n      );\n      if (file) {\n        this.fileData.push(file);\n        this.fileUrls.push(`${file.Name}`);\n        // this.profileImage = base64data;\n      }\n    };\n  }\n}\n","<verben-dialogue\n  [showCloseIcon]=\"false\"\n  [dismissOutsideClick]=\"false\"\n  [closeOnEscape]=\"true\"\n  [size]=\"'medium'\"\n  [mode]=\"'dialogue'\"\n  [customClass]=\"'ticket-dialog'\"\n  [disableFooter]=\"true\"\n  (openModal)=\"onModalOpen($event)\"\n  [isVisible]=\"isVisible\"\n  [bodyTemplate]=\"bodyTemplate\"\n  (closeModal)=\"onModalClose($event)\"\n>\n  <ng-template #bodyTemplate>\n    <div class=\"dialog-body p-[25px] flex flex-col gap-4\">\n      <div class=\"dialog-header flex flex-col gap-1\">\n        <div class=\"dialog-title font-bold text-xl\">\n          {{ this.selectedTicket ? \"Edit Ticket\" : \"Create Ticket\" }}\n        </div>\n        <div class=\"dialog-subtitle\">\n          {{\n            this.selectedTicket\n              ? \"Fill the form below to edit selected ticket\"\n              : \"Fill the form below to create a ticket\"\n          }}\n        </div>\n      </div>\n      <!-- <verbena-textarea name=\"Test\" [(ngModel)]=\"test\" />\n      <button (click)=\"logTest()\">Log</button> -->\n      <div\n        [formGroup]=\"createTicketForm\"\n        class=\"add-app-form main-form-container flex flex-col gap-2\"\n      >\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Title</div>\n          <verbena-input\n            name=\"Title\"\n            placeHolder=\"Title\"\n            formControlName=\"Title\"\n          />\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Description</div>\n          <verbena-input name=\"Description\" formControlName=\"Description\" />\n        </div>\n        <div\n          *ngIf=\"this.selectedTicket\"\n          class=\"form-input-container flex flex-col gap-1\"\n        >\n          <div class=\"font-medium\">Current Handler</div>\n          <verbena-input\n            name=\"CurrentHandler\"\n            placeHolder=\"Current Handler\"\n            formControlName=\"CurrentHandler\"\n          />\n        </div>\n        <div\n          *ngIf=\"this.selectedTicket\"\n          class=\"form-input-container flex flex-col gap-1\"\n        >\n          <div class=\"font-medium\">Last Handler</div>\n          <verbena-input\n            name=\"LastHandler\"\n            placeHolder=\"Last Handler\"\n            formControlName=\"LastHandler\"\n          />\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Priority</div>\n          <verben-drop-down\n            width=\"100%\"\n            name=\"Priority\"\n            placeholder=\"Select Priority\"\n            [options]=\"priorityOptions\"\n            optionLabel=\"Name\"\n            optionValue=\"Code\"\n            formControlName=\"Priority\"\n          >\n          </verben-drop-down>\n        </div>\n        <div class=\"form-input-container flex flex-col gap-1\">\n          <div class=\"font-medium\">Status</div>\n          <verben-drop-down\n            width=\"100%\"\n            name=\"Status\"\n            [disabled]=\"true\"\n            placeholder=\"Select Status\"\n            [options]=\"statusOptions\"\n            formControlName=\"Status\"\n          >\n          </verben-drop-down>\n        </div>\n        <div class=\"attachment-section p-2 flex flex-col gap-3\">\n          <div class=\"attachments-container grid grid-cols-3 gap-2\">\n            <ng-container *ngFor=\"let file of this.fileUrls\">\n              <app-file-render [fileUrl]=\"file\"></app-file-render>\n            </ng-container>\n          </div>\n          <div\n            class=\"upload-section flex flex-col flex-1 items-center justify-center gap-2\"\n          >\n            <div class=\"flex justify-center\">\n              <verbena-button\n                [useIcon]=\"true\"\n                [icon]=\"'upload'\"\n                class=\"verben-secondary-button\"\n                [text]=\"'Upload'\"\n                (click)=\"triggerFileUpload()\"\n              ></verbena-button>\n            </div>\n            <div class=\"upload-caption text-sm text-center\">\n              Include Attachments\n            </div>\n          </div>\n        </div>\n      </div>\n      <div class=\"dialog-button-container flex justify-end gap-2\">\n        <verbena-button\n          width=\"100%\"\n          class=\"verben-secondary-button\"\n          [text]=\"'Close'\"\n          (click)=\"onModalClose($event)\"\n        >\n        </verbena-button>\n        <verbena-button\n          [disable]=\"!this.checkForm()\"\n          width=\"100%\"\n          class=\"verben-primary-button\"\n          [text]=\"'Save'\"\n          (click)=\"save()\"\n        >\n        </verbena-button>\n      </div>\n    </div>\n  </ng-template>\n</verben-dialogue>\n"]}