tui-image-editor-angular3 14.0.2 → 14.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/tui-image-editor.component.mjs +2 -2
- package/fesm2015/tui-image-editor-angular2.mjs +2484 -205
- package/fesm2015/tui-image-editor-angular2.mjs.map +1 -1
- package/fesm2015/tui-image-editor-angular3.mjs +1 -1
- package/fesm2015/tui-image-editor-angular3.mjs.map +1 -1
- package/fesm2020/tui-image-editor-angular2.mjs +2412 -416
- package/fesm2020/tui-image-editor-angular2.mjs.map +1 -1
- package/fesm2020/tui-image-editor-angular3.mjs +1 -1
- package/fesm2020/tui-image-editor-angular3.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -93,7 +93,7 @@ export class TuiImageEditorComponent {
|
|
|
93
93
|
this.imageEditor._invoker.on(eventNames.AFTER_UNDO, this.onAfterUndoEventListener);
|
|
94
94
|
this.imageEditor._invoker.on(eventNames.AFTER_REDO, this.onAfterRedoEventListener);
|
|
95
95
|
if (this.initialImage != null) {
|
|
96
|
-
this.
|
|
96
|
+
this.onLoad(this.initialImage);
|
|
97
97
|
}
|
|
98
98
|
}
|
|
99
99
|
destroyImageEditor() {
|
|
@@ -291,4 +291,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
291
291
|
}], template: [{
|
|
292
292
|
type: Input
|
|
293
293
|
}] } });
|
|
294
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tui-image-editor.component.js","sourceRoot":"","sources":["../../../../projects/tui-image-editor-angular2/src/lib/tui-image-editor.component.ts","../../../../projects/tui-image-editor-angular2/src/lib/tui-image-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport {\r\n  cropModes,\r\n  defaultIconPath,\r\n  drawingModes,\r\n  eventNames,\r\n  historyNames,\r\n  objectTypes,\r\n  zoomModes,\r\n} from './consts';\r\nimport { Command } from './interfaces/command';\r\nimport { HistoryItem, HistoryItemType } from './interfaces/history-item';\r\nimport { ImageSize } from './interfaces/image-size';\r\nimport { HistoryService } from './services/history.service';\r\nimport { FilterComponent } from './submenus/filter/filter.component';\r\nimport heic2any from \"heic2any\";\r\nimport {\r\n  clearSelection,\r\n  dataUrlToBlob,\r\n  isFileApiSupported,\r\n  isSilentCommand,\r\n} from './utils';\r\n// const ImageEditor = require('tui-image-editor');\r\nimport ImageEditor from 'tui-image-editor';\r\n\r\n@Component({\r\n  selector: 'tui-image-editor',\r\n  templateUrl: 'tui-image-editor.component.html',\r\n  styleUrls: ['tui-image-editor.component.scss'],\r\n  providers: [HistoryService],\r\n})\r\nexport class TuiImageEditorComponent\r\n  implements OnInit, OnChanges, AfterViewInit, OnDestroy\r\n{\r\n  @ViewChild('imageContainer') imageContainer: ElementRef;\r\n  @ViewChild('loadBtn') loadBtn: ElementRef;\r\n  @Output() onInitialization: EventEmitter<any> = new EventEmitter();\r\n  @Input() options: {\r\n    usageStatistics: boolean;\r\n    selectionStyle?: {\r\n      cornerStyle: string;\r\n      cornerSize: number;\r\n      cornerColor: string;\r\n      cornerStrokeColor: string;\r\n      transparentCorners: boolean;\r\n      lineWidth: number;\r\n      borderColor: string;\r\n      rotatingPointOffset: number;\r\n    };\r\n    applyCropSelectionStyle: boolean;\r\n    applyGroupSelectionStyle: boolean;\r\n  } = {\r\n    usageStatistics: false,\r\n    selectionStyle: {\r\n      cornerStyle: 'circle',\r\n      cornerSize: 32,\r\n      cornerColor: '#fff',\r\n      cornerStrokeColor: '#fff',\r\n      transparentCorners: false,\r\n      lineWidth: 4,\r\n      borderColor: '#fff',\r\n      rotatingPointOffset: 500,\r\n    },\r\n    applyCropSelectionStyle: true,\r\n    applyGroupSelectionStyle: true,\r\n  };\r\n  @Input() initialImage: string | File;\r\n  @Input() template='default';\r\n  public imageEditor: any;\r\n  public imageLoaded= false;\r\n  public initializeImgUrl: string = null;\r\n  public imageChosen: boolean = false;\r\n  public activeObjectId: number;\r\n  public submenu:\r\n    | 'crop'\r\n    | 'flip'\r\n    | 'rotate'\r\n    | 'filter'\r\n    | 'text'\r\n    | 'icon'\r\n    | 'shape'\r\n    | 'draw'\r\n    | 'mask'\r\n    | null;\r\n  showSubmenu=false;\r\n  isMenuExpanded=false;\r\n  public rotation: number = 0;\r\n  public onObjectActivatedEventListener: any;\r\n  public onExecuteCommandEventListener: any;\r\n  public onAfterUndoEventListener: any;\r\n  public onAfterRedoEventListener: any;\r\n  private historyServiceSubscription: Subscription;\r\n\r\n  constructor(private historyService: HistoryService) {\r\n    this.onObjectActivatedEventListener = this.onObjectActivated.bind(this);\r\n    this.onExecuteCommandEventListener = this.onExecuteCommand.bind(this);\r\n    this.onAfterUndoEventListener = this.onAfterUndo.bind(this);\r\n    this.onAfterRedoEventListener = this.onAfterRedo.bind(this);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.historyServiceSubscription =\r\n      this.historyService.onChangeEmitter.subscribe((items) =>\r\n        this.onActiveHistoryElementChanged(items)\r\n      );\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      (changes['options'] && changes['options'].firstChange == false) ||\r\n      (changes['initialImage'] && changes['initialImage'].firstChange == false)\r\n    ) {\r\n      this.destroyImageEditor();\r\n      this.initializeImageEditor();\r\n    }\r\n  }\r\n\r\n  initializeImageEditor() {\r\n    this.historyService.clear();\r\n\r\n    this.imageEditor = new ImageEditor(\r\n      this.imageContainer.nativeElement,\r\n      this.options\r\n    );\r\n\r\n    this.onInitialization.emit({\r\n      imageEditor:this.imageEditor\r\n    })\r\n\r\n    console.debug(this.imageEditor);\r\n\r\n    this.imageEditor.registerIcons(defaultIconPath);\r\n\r\n    this.imageEditor.on(\r\n      eventNames.OBJECT_ACTIVATED,\r\n      this.onObjectActivatedEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.EXECUTE_COMMAND,\r\n      this.onExecuteCommandEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.AFTER_UNDO,\r\n      this.onAfterUndoEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.AFTER_REDO,\r\n      this.onAfterRedoEventListener\r\n    );\r\n\r\n    if (this.initialImage != null) {\r\n      this.loadImage(this.initialImage);\r\n    }\r\n  }\r\n\r\n  destroyImageEditor() {\r\n    console.log('DISPOSING IMAGE EDITOR...');\r\n    if (this.imageEditor != null) {\r\n      this.imageEditor.off(\r\n        eventNames.OBJECT_ACTIVATED,\r\n        this.onObjectActivatedEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.EXECUTE_COMMAND,\r\n        this.onExecuteCommandEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.AFTER_UNDO,\r\n        this.onAfterUndoEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.AFTER_REDO,\r\n        this.onAfterRedoEventListener\r\n      );\r\n      const canvas = this.imageEditor._graphics._canvas;\r\n      this.imageEditor.destroy();\r\n      canvas.dispose();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    var that = this;\r\n    this.loadBtn.nativeElement.style.zIndex = '1'\r\n    this.imageContainer.nativeElement.style.zIndex = '-1'\r\n\r\n    setTimeout(() => {\r\n      //   this.imageEditor.on(eventNames.SELECTION_CLEARED, function () {\r\n      //     that.activeObjectId = null;\r\n      //     if (that.submenu === 'text') {\r\n      //       that.imageEditor.changeCursor('text');\r\n      //     } else if (that.submenu !== 'draw' && that.submenu !== 'crop') {\r\n      //       that.imageEditor.stopDrawingMode();\r\n      //     }\r\n      //   });\r\n      that.initializeImageEditor();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.initializeImgUrl != null) {\r\n      URL.revokeObjectURL(this.initializeImgUrl);\r\n    }\r\n    this.destroyImageEditor();\r\n    this.historyServiceSubscription?.unsubscribe();\r\n  }\r\n\r\n  private onObjectActivated(props) {\r\n    console.debug(props);\r\n    this.activeObjectId = props?.id;\r\n    if (props?.id != null) {\r\n      if (\r\n        [\r\n          objectTypes.shapeRect,\r\n          objectTypes.shapeCircle,\r\n          objectTypes.shapeTriangle,\r\n        ].indexOf(props.type) > -1\r\n      ) {\r\n        this.showMenu('shape', false);\r\n      } else if (\r\n        props.type === objectTypes.line ||\r\n        props.type === objectTypes.straightLine\r\n      ) {\r\n        this.showMenu('draw', false);\r\n      } else if (\r\n        props.type === objectTypes.itext ||\r\n        props.type === objectTypes.text\r\n      ) {\r\n        this.showMenu('text', false);\r\n      } else if (props.type === objectTypes.icon) {\r\n        this.showMenu('icon', false);\r\n      } else if (props.type === objectTypes.image) {\r\n        this.showMenu('mask', false);\r\n      }\r\n    }\r\n  }\r\n\r\n  private onExecuteCommand(command: string | Command) {\r\n    if (!isSilentCommand(command)) {\r\n      this.historyService.add(command, this.imageEditor);\r\n    }\r\n  }\r\n\r\n  private onAfterUndo() {\r\n    this.historyService.prev();\r\n  }\r\n\r\n  private onAfterRedo() {\r\n    this.historyService.next();\r\n  }\r\n\r\n  onLoad(event:any){\r\n    this.loadBtn.nativeElement.style.zIndex = '-1'\r\n    this.imageContainer.nativeElement.style.zIndex = '1'\r\n    this.loadImage(event);\r\n  }\r\n\r\n  loadImage(file: string | File | Blob) {\r\n    const type=(<any>file)?.name?.split('.').pop();\r\n    if(type?.toLowerCase()==='heic'){\r\n      heic2any({blob:<Blob>file}).then(data=>{\r\n        file=<Blob>data;\r\n        this.uploadIMage(file);\r\n      }).catch(err=>{\r\n        console.log(\"Err\",err)\r\n      })\r\n    }else{\r\n      this.uploadIMage(file);\r\n    } \r\n  }\r\n\r\n  uploadIMage(file:string | File | Blob){\r\n    if (file != null) {\r\n      let imageUrl: string = null;\r\n      if (typeof file === 'string') {\r\n        imageUrl = file;\r\n      } else {\r\n        if (!isFileApiSupported()) {\r\n          alert('This browser does not support file-api');\r\n          return;\r\n        }\r\n        imageUrl = URL.createObjectURL(file);\r\n      }\r\n\r\n      if (this.initializeImgUrl != null && imageUrl != this.initializeImgUrl) {\r\n        URL.revokeObjectURL(this.initializeImgUrl);\r\n      }\r\n\r\n      this.initializeImgUrl = imageUrl;\r\n      this.imageEditor\r\n        .loadImageFromURL(this.initializeImgUrl, 'RandomFileName')\r\n        .then((sizeValue: ImageSize) => {\r\n          this.imageChosen = true;\r\n          this.showMenu('draw',false);\r\n          this.exitCropOnAction();\r\n          this.imageEditor.clearUndoStack();\r\n          this.imageEditor.clearRedoStack();\r\n          this.historyService.clear();\r\n          this.imageEditor._invoker.fire(\r\n            eventNames.EXECUTE_COMMAND,\r\n            historyNames.LOAD_IMAGE\r\n          );\r\n        })\r\n        ['catch']((message) => Promise.reject(message));\r\n    }\r\n  }\r\n\r\n  resetImage() {\r\n    if (this.initializeImgUrl != null) {\r\n      this.loadImage(this.initializeImgUrl);\r\n    }\r\n  }\r\n\r\n  getImage(\r\n    options: {\r\n      format: 'jpeg' | 'png';\r\n      quality: number;\r\n      multiplier: number;\r\n      left?: number;\r\n      top?: number;\r\n      width?: number;\r\n      height?: number;\r\n    } = {\r\n      format: 'png',\r\n      quality: 1,\r\n      multiplier: 1,\r\n    }\r\n  ): string {\r\n    if (this.imageChosen) {\r\n      return this.imageEditor.toDataURL(options);\r\n    }\r\n    return null;\r\n  }\r\n\r\n  exitCropOnAction() {\r\n    this.hideMenu('crop');\r\n  }\r\n\r\n  hideMenu(\r\n    menuName:\r\n      | 'crop'\r\n      | 'flip'\r\n      | 'rotate'\r\n      | 'filter'\r\n      | 'text'\r\n      | 'icon'\r\n      | 'shape'\r\n      | 'draw'\r\n      | 'mask'\r\n      | null\r\n  ) {\r\n    if (this.submenu == menuName) {\r\n      this.submenu = null;\r\n      this.showSubmenu=false;\r\n      clearSelection(this.imageEditor);\r\n      this.imageEditor.stopDrawingMode();\r\n    }\r\n  }\r\n\r\n  onActiveHistoryElementChanged(items: HistoryItem[]) {\r\n    let rotationEvents = items.filter((i) => i.type === HistoryItemType.Rotate);\r\n    if (rotationEvents.length > 0) {\r\n      let lastRotationEvent = rotationEvents[rotationEvents.length - 1];\r\n      this.rotation = lastRotationEvent.args[0];\r\n    } else {\r\n      this.rotation = 0;\r\n    }\r\n  }\r\n\r\n  showMenu(\r\n    menuName:\r\n      | 'crop'\r\n      | 'flip'\r\n      | 'rotate'\r\n      | 'filter'\r\n      | 'text'\r\n      | 'icon'\r\n      | 'shape'\r\n      | 'draw'\r\n      | 'mask'\r\n      | null,\r\n    discardSelection: boolean = true\r\n  ) {\r\n    this.submenu = menuName;\r\n    this.showSubmenu=true;\r\n    if (discardSelection) {\r\n      clearSelection(this.imageEditor);\r\n    }\r\n    this.imageEditor.stopDrawingMode();\r\n    //this.stopShape();\r\n    // this._changeMenu(menuName, toggle, discardSelection);\r\n\r\n    // if (this.submenu == 'draw') {\r\n    //   this.setDrawMode('free', {\r\n    //     width: this.drawStrokeWidthValue,\r\n    //     color: this.drawStrokeColor,\r\n    //   });\r\n    // }\r\n  }\r\n}\r\n","<div *ngIf=\"template==='default';else newImageEditor\"\r\n  class=\"tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-justify-content-center tui-image-editor-h-100 tui-image-editor-w-100 tui-image-editor-container\">\r\n  <div\r\n    class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-justify-content-center tui-image-editor-align-items-center\">\r\n    <div\r\n      class=\"tui-image-editor-help-menu tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-align-items-center tui-image-editor-justify-content-center tui-image-editor-p-1\">\r\n      <div></div>\r\n      <!-- <div #loadBtn style=\"position: absolute;\"\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-load (loadImage)=\"loadImage($event)\"></tui-image-editor-menus-buttons-load>\r\n        <tui-image-editor-menus-buttons-download [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-download>\r\n      </div> -->\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-zoom-in [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-in>\r\n        <tui-image-editor-menus-buttons-zoom-out [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-out>\r\n        <tui-image-editor-menus-buttons-drag [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-drag>\r\n      </div>\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-history [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-history>\r\n        <tui-image-editor-menus-buttons-undo [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-undo>\r\n        <tui-image-editor-menus-buttons-redo [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-redo>\r\n        <tui-image-editor-menus-buttons-reset [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"\r\n          (resetImage)=\"resetImage()\"></tui-image-editor-menus-buttons-reset>\r\n      </div>\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-delete [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-delete>\r\n        <tui-image-editor-menus-buttons-delete-all [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-delete-all>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- <div #imageContainer\r\n    class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\"\r\n    [style.height]=\"'0'\"></div> -->\r\n    <div style=\"position: relative;height: 100%; display: flex; justify-content: center; align-items: center;\">\r\n      <div #loadBtn style=\"position: absolute;\"\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-load (loadImage)=\"onLoad($event)\"></tui-image-editor-menus-buttons-load>\r\n      </div>\r\n      <div style=\"position: absolute;height: 100%; width: 100%;\" #imageContainer\r\n        class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\">\r\n      </div>\r\n    </div>\r\n  <div class=\"tui-image-editor-submenu\" *ngIf=\"submenu != null\">\r\n    <tui-image-editor-submenus-crop *ngIf=\"submenu == 'crop'\" [imageEditor]=\"imageEditor\"\r\n      (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-submenus-crop>\r\n    <tui-image-editor-submenus-flip *ngIf=\"submenu == 'flip'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-flip>\r\n    <tui-image-editor-submenus-rotate *ngIf=\"submenu == 'rotate'\" [imageEditor]=\"imageEditor\"\r\n      [(rotation)]=\"rotation\"></tui-image-editor-submenus-rotate>\r\n    <tui-image-editor-submenus-draw *ngIf=\"submenu == 'draw'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-draw>\r\n    <tui-image-editor-submenus-shape *ngIf=\"submenu == 'shape'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-shape>\r\n    <tui-image-editor-submenus-icon *ngIf=\"submenu == 'icon'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-icon>\r\n    <tui-image-editor-submenus-text *ngIf=\"submenu == 'text'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-text>\r\n    <tui-image-editor-submenus-mask *ngIf=\"submenu == 'mask'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-mask>\r\n    <tui-image-editor-submenus-filter *ngIf=\"submenu == 'filter'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-filter>\r\n  </div>\r\n  <div\r\n    class=\"tui-image-editor-controls tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-justify-content-center\">\r\n    <div\r\n      class=\"tui-image-editor-menu tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap tui-image-editor-align-items-center\">\r\n      <tui-image-editor-menus-buttons-crop [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'crop'\"\r\n        (clicked)=\"submenu == 'crop' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-crop>\r\n      <tui-image-editor-menus-buttons-flip [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'flip'\"\r\n        (clicked)=\"submenu == 'flip' ? hideMenu($event) : showMenu($event)\">\r\n      </tui-image-editor-menus-buttons-flip>\r\n      <tui-image-editor-menus-buttons-rotate [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'rotate'\"\r\n        (clicked)=\"submenu == 'rotate' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-rotate>\r\n      <tui-image-editor-menus-buttons-draw [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'draw'\"\r\n        (clicked)=\"submenu == 'draw' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-draw>\r\n      <tui-image-editor-menus-buttons-shape [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'shape'\"\r\n        (clicked)=\"submenu == 'shape' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-shape>\r\n      <tui-image-editor-menus-buttons-icon [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'icon'\"\r\n        (clicked)=\"submenu == 'icon' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-icon>\r\n      <tui-image-editor-menus-buttons-text [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'text'\"\r\n        (clicked)=\"submenu == 'text' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-text>\r\n      <tui-image-editor-menus-buttons-mask [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'mask'\"\r\n        (clicked)=\"submenu == 'mask' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-mask>\r\n      <tui-image-editor-menus-buttons-filter [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'filter'\"\r\n        (clicked)=\"submenu == 'filter' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-filter>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #newImageEditor>\r\n  <div class=\"new-template tui-image-editor-container\">\r\n    <div class=\"image-load-container\">\r\n      <div style=\"position: relative;height: 100%; display: flex; justify-content: center; align-items: center;\">\r\n        <div #loadBtn style=\"position: absolute;\"\r\n          class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n          <tui-image-editor-menus-buttons-load (loadImage)=\"onLoad($event)\"></tui-image-editor-menus-buttons-load>\r\n        </div>\r\n        <div style=\"position: absolute;height: 100%; width: 100%;\" #imageContainer\r\n          class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\">\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"tools-container\" style=\"position: relative;\" [style.width.px]=\"isMenuExpanded ? 160 : 80\">\r\n      <div class=\"primary-tools\">\r\n        <div class=\"selected-option\" style=\"cursor: pointer;\" (click)=\"showSubmenu=!showSubmenu\">\r\n          <svg *ngIf=\"!showSubmenu\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path opacity=\"0.7\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n              d=\"M9.3809 2.67601H17.0011C17.5527 2.67601 18 3.12327 18 3.67491C18 4.22654 17.5527 4.6738 17.0011 4.6738H9.38083C8.94507 6.20757 7.53168 7.33419 5.86014 7.33419C4.18856 7.33419 2.77524 6.20757 2.33944 4.6738H0.998897C0.447224 4.6738 0 4.22651 0 3.67487C0 3.12323 0.447224 2.67597 0.998897 2.67601H2.33951C2.77527 1.14224 4.18863 0.015625 5.86021 0.015625C7.53175 0.015625 8.9451 1.14224 9.3809 2.67601ZM4.19868 3.67484C4.19868 4.59097 4.944 5.33632 5.86017 5.33632C6.77635 5.33632 7.52166 4.59097 7.52166 3.67484C7.52166 2.7587 6.77635 2.01335 5.86017 2.01335C4.944 2.01335 4.19868 2.7587 4.19868 3.67484ZM15.6581 11.3275H17.0011C17.5528 11.3275 18 11.7748 18 12.3264C18 12.8781 17.5528 13.3253 17.0011 13.3253H15.6581C15.2224 14.8591 13.809 15.9857 12.1374 15.9857C10.4659 15.9857 9.05254 14.8591 8.61674 13.3253H0.998897C0.447224 13.3253 0 12.8781 0 12.3264C0 11.7748 0.447224 11.3275 0.998897 11.3275H8.61674C9.05251 9.79378 10.4659 8.66716 12.1374 8.66716C13.809 8.66716 15.2223 9.79378 15.6581 11.3275ZM10.476 12.3264C10.476 13.2426 11.2213 13.9879 12.1374 13.9879C13.0536 13.9879 13.799 13.2426 13.7989 12.3264C13.7989 11.4103 13.0536 10.665 12.1374 10.665C11.2213 10.665 10.476 11.4103 10.476 12.3264Z\"\r\n              fill=\"#25282B\" />\r\n          </svg>\r\n          <svg *ngIf=\"showSubmenu\" width=\"42\" height=\"40\" viewBox=\"0 0 42 40\" fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <rect width=\"42\" height=\"40\" rx=\"8\" fill=\"#25282B\" fill-opacity=\"0.1\" />\r\n            <g opacity=\"0.7\">\r\n              <path\r\n                d=\"M16.1375 25.9935C15.8433 26.0108 15.554 25.9119 15.3305 25.7176C14.8898 25.2691 14.8898 24.5447 15.3305 24.0962L24.9801 14.3337C25.4384 13.8998 26.1576 13.9239 26.5865 14.3876C26.9744 14.807 26.997 15.4515 26.6395 15.8976L16.9331 25.7176C16.7125 25.9091 16.4278 26.0078 16.1375 25.9935Z\"\r\n                fill=\"#25282B\" />\r\n              <path\r\n                d=\"M25.7732 25.9938C25.475 25.9925 25.1893 25.8728 24.9776 25.6603L15.328 15.8978C14.9197 15.4155 14.9752 14.6896 15.452 14.2765C15.8775 13.9078 16.5051 13.9078 16.9306 14.2765L26.637 24.039C27.0952 24.473 27.1189 25.2007 26.6899 25.6643C26.6728 25.6827 26.6552 25.7006 26.637 25.7178C26.3993 25.9269 26.0865 26.0268 25.7732 25.9938Z\"\r\n                fill=\"#25282B\" />\r\n            </g>\r\n          </svg>\r\n        </div>\r\n        <div class=\"hr\">\r\n\r\n        </div>\r\n        <div class=\"menu\">\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-draw #penMenu [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'draw'\"\r\n              (clicked)=\"submenu == 'draw' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-draw>\r\n          </div>\r\n          <!-- <div class=\"eraser\">\r\n  \r\n          </div> -->\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-text [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'text'\"\r\n              (clicked)=\"submenu == 'text' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-text>\r\n          </div>\r\n          <div class=\"tool-icon-group\">\r\n            <tui-image-editor-menus-buttons-zoom-in [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-in>\r\n            <tui-image-editor-menus-buttons-zoom-out [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-out>\r\n            <tui-image-editor-menus-buttons-drag [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-drag>\r\n          </div>\r\n          <div class=\"tool-icon-group\">\r\n            <tui-image-editor-menus-buttons-history\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-history>\r\n            <tui-image-editor-menus-buttons-undo [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-undo>\r\n            <tui-image-editor-menus-buttons-redo [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-redo>\r\n            <tui-image-editor-menus-buttons-reset [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"\r\n              (resetImage)=\"resetImage()\"></tui-image-editor-menus-buttons-reset>\r\n          </div>\r\n\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-crop [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'crop'\"\r\n              (clicked)=\"submenu == 'crop' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-crop>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-flip [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'flip'\"\r\n              (clicked)=\"submenu == 'flip' ? hideMenu($event) : showMenu($event)\">\r\n            </tui-image-editor-menus-buttons-flip>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-rotate [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'rotate'\"\r\n              (clicked)=\"submenu == 'rotate' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-rotate>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-shape [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'shape'\"\r\n              (clicked)=\"submenu == 'shape' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-shape>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-icon [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'icon'\"\r\n              (clicked)=\"submenu == 'icon' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-icon>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-mask [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'mask'\"\r\n              (clicked)=\"submenu == 'mask' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-mask>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-filter [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'filter'\"\r\n              (clicked)=\"submenu == 'filter' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-filter>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-download [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-download>\r\n          </div>\r\n        </div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n        <div class=\"sub-menu\">\r\n          <div class=\"tui-image-editor-submenu new\" [style.right.px]=\"isMenuExpanded ? 160 : 80\"\r\n            *ngIf=\"submenu != null && showSubmenu\">\r\n            <tui-image-editor-submenus-crop *ngIf=\"submenu == 'crop'\" [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-submenus-crop>\r\n            <tui-image-editor-submenus-flip *ngIf=\"submenu == 'flip'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-flip>\r\n            <tui-image-editor-submenus-rotate *ngIf=\"submenu == 'rotate'\" [imageEditor]=\"imageEditor\"\r\n              [(rotation)]=\"rotation\"></tui-image-editor-submenus-rotate>\r\n            <tui-image-editor-submenus-draw *ngIf=\"submenu == 'draw'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-draw>\r\n            <tui-image-editor-submenus-shape *ngIf=\"submenu == 'shape'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-shape>\r\n            <tui-image-editor-submenus-icon *ngIf=\"submenu == 'icon'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-icon>\r\n            <tui-image-editor-submenus-text *ngIf=\"submenu == 'text'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-text>\r\n            <tui-image-editor-submenus-mask *ngIf=\"submenu == 'mask'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-mask>\r\n            <tui-image-editor-submenus-filter *ngIf=\"submenu == 'filter'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-filter>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"toggler\" (click)=\"isMenuExpanded=!isMenuExpanded\" style=\"cursor: pointer;\">\r\n        <svg *ngIf=\"!isMenuExpanded\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n          xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n            d=\"M0.864575 7.34425C0.503475 7.70535 0.503475 8.29473 0.864575 8.65583L7.93771 15.7287C8.29937 16.0904 8.88768 16.0904 9.2493 15.7287L9.64494 15.3331C10.0069 14.9711 10.007 14.3831 9.64498 14.0211L4.27939 8.65599C3.91733 8.29401 3.91733 7.7059 4.27939 7.34393L9.64494 1.97882C10.007 1.6168 10.007 1.02885 9.6449 0.66683L9.24926 0.27119C8.88816 -0.0899105 8.29877 -0.0899105 7.93767 0.27119L0.864575 7.34425ZM15.4293 0.27111C15.7907 -0.0903898 16.3796 -0.0903499 16.741 0.27111L17.1367 0.66675C17.498 1.02805 17.498 1.61744 17.1367 1.97878L11.7714 7.34393C11.4094 7.70595 11.4094 8.29398 11.7714 8.65599L17.1367 14.0211C17.4982 14.3825 17.4981 14.9717 17.1367 15.3331L16.7411 15.7288C16.3795 16.0904 15.7909 16.0904 15.4293 15.7288L8.98444 9.28372C7.17658 11.0898 7.63387 10.6318 8.98312 9.2824L8.35659 8.65583C7.99525 8.29449 7.99529 7.70554 8.35659 7.34421L15.4293 0.27111Z\"\r\n            fill=\"#515355\" />\r\n        </svg>\r\n        <svg *ngIf=\"isMenuExpanded\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n          xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n            d=\"M17.1354 8.65575C17.4965 8.29465 17.4965 7.70527 17.1354 7.34417L10.0623 0.27127C9.70063 -0.0903886 9.11232 -0.0903885 8.7507 0.271271L8.35506 0.666911C7.99308 1.02889 7.993 1.61688 8.35502 1.97894L13.7206 7.34401C14.0827 7.70599 14.0827 8.2941 13.7206 8.65607L8.35506 14.0212C7.993 14.3832 7.99304 14.9712 8.3551 15.3332L8.75074 15.7288C9.11184 16.0899 9.70123 16.0899 10.0623 15.7288L17.1354 8.65575ZM2.57075 15.7289C2.20929 16.0904 1.62042 16.0904 1.25896 15.7289L0.863319 15.3333C0.50202 14.972 0.50198 14.3826 0.863319 14.0212L6.22863 8.65607C6.59065 8.29406 6.59065 7.70603 6.22863 7.34401L0.86328 1.9789C0.50182 1.61748 0.50186 1.02829 0.86328 0.666871L1.25892 0.27123C1.62054 -0.0903879 2.20909 -0.090428 2.57071 0.27123L9.01556 6.71628C10.8234 4.91023 10.3661 5.36824 9.01688 6.7176L9.64341 7.34417C10.0047 7.70551 10.0047 8.29446 9.64341 8.6558L2.57075 15.7289Z\"\r\n            fill=\"#515355\" />\r\n        </svg>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tui-image-editor.component.js","sourceRoot":"","sources":["../../../../projects/tui-image-editor-angular2/src/lib/tui-image-editor.component.ts","../../../../projects/tui-image-editor-angular2/src/lib/tui-image-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport {\r\n  cropModes,\r\n  defaultIconPath,\r\n  drawingModes,\r\n  eventNames,\r\n  historyNames,\r\n  objectTypes,\r\n  zoomModes,\r\n} from './consts';\r\nimport { Command } from './interfaces/command';\r\nimport { HistoryItem, HistoryItemType } from './interfaces/history-item';\r\nimport { ImageSize } from './interfaces/image-size';\r\nimport { HistoryService } from './services/history.service';\r\nimport { FilterComponent } from './submenus/filter/filter.component';\r\nimport heic2any from \"heic2any\";\r\nimport {\r\n  clearSelection,\r\n  dataUrlToBlob,\r\n  isFileApiSupported,\r\n  isSilentCommand,\r\n} from './utils';\r\n// const ImageEditor = require('tui-image-editor');\r\nimport ImageEditor from 'tui-image-editor';\r\n\r\n@Component({\r\n  selector: 'tui-image-editor',\r\n  templateUrl: 'tui-image-editor.component.html',\r\n  styleUrls: ['tui-image-editor.component.scss'],\r\n  providers: [HistoryService],\r\n})\r\nexport class TuiImageEditorComponent\r\n  implements OnInit, OnChanges, AfterViewInit, OnDestroy\r\n{\r\n  @ViewChild('imageContainer') imageContainer: ElementRef;\r\n  @ViewChild('loadBtn') loadBtn: ElementRef;\r\n  @Output() onInitialization: EventEmitter<any> = new EventEmitter();\r\n  @Input() options: {\r\n    usageStatistics: boolean;\r\n    selectionStyle?: {\r\n      cornerStyle: string;\r\n      cornerSize: number;\r\n      cornerColor: string;\r\n      cornerStrokeColor: string;\r\n      transparentCorners: boolean;\r\n      lineWidth: number;\r\n      borderColor: string;\r\n      rotatingPointOffset: number;\r\n    };\r\n    applyCropSelectionStyle: boolean;\r\n    applyGroupSelectionStyle: boolean;\r\n  } = {\r\n    usageStatistics: false,\r\n    selectionStyle: {\r\n      cornerStyle: 'circle',\r\n      cornerSize: 32,\r\n      cornerColor: '#fff',\r\n      cornerStrokeColor: '#fff',\r\n      transparentCorners: false,\r\n      lineWidth: 4,\r\n      borderColor: '#fff',\r\n      rotatingPointOffset: 500,\r\n    },\r\n    applyCropSelectionStyle: true,\r\n    applyGroupSelectionStyle: true,\r\n  };\r\n  @Input() initialImage: string | File;\r\n  @Input() template='default';\r\n  public imageEditor: any;\r\n  public imageLoaded= false;\r\n  public initializeImgUrl: string = null;\r\n  public imageChosen: boolean = false;\r\n  public activeObjectId: number;\r\n  public submenu:\r\n    | 'crop'\r\n    | 'flip'\r\n    | 'rotate'\r\n    | 'filter'\r\n    | 'text'\r\n    | 'icon'\r\n    | 'shape'\r\n    | 'draw'\r\n    | 'mask'\r\n    | null;\r\n  showSubmenu=false;\r\n  isMenuExpanded=false;\r\n  public rotation: number = 0;\r\n  public onObjectActivatedEventListener: any;\r\n  public onExecuteCommandEventListener: any;\r\n  public onAfterUndoEventListener: any;\r\n  public onAfterRedoEventListener: any;\r\n  private historyServiceSubscription: Subscription;\r\n\r\n  constructor(private historyService: HistoryService) {\r\n    this.onObjectActivatedEventListener = this.onObjectActivated.bind(this);\r\n    this.onExecuteCommandEventListener = this.onExecuteCommand.bind(this);\r\n    this.onAfterUndoEventListener = this.onAfterUndo.bind(this);\r\n    this.onAfterRedoEventListener = this.onAfterRedo.bind(this);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.historyServiceSubscription =\r\n      this.historyService.onChangeEmitter.subscribe((items) =>\r\n        this.onActiveHistoryElementChanged(items)\r\n      );\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      (changes['options'] && changes['options'].firstChange == false) ||\r\n      (changes['initialImage'] && changes['initialImage'].firstChange == false)\r\n    ) {\r\n      this.destroyImageEditor();\r\n      this.initializeImageEditor();\r\n    }\r\n  }\r\n\r\n  initializeImageEditor() {\r\n    this.historyService.clear();\r\n\r\n    this.imageEditor = new ImageEditor(\r\n      this.imageContainer.nativeElement,\r\n      this.options\r\n    );\r\n\r\n    this.onInitialization.emit({\r\n      imageEditor:this.imageEditor\r\n    })\r\n\r\n    console.debug(this.imageEditor);\r\n\r\n    this.imageEditor.registerIcons(defaultIconPath);\r\n\r\n    this.imageEditor.on(\r\n      eventNames.OBJECT_ACTIVATED,\r\n      this.onObjectActivatedEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.EXECUTE_COMMAND,\r\n      this.onExecuteCommandEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.AFTER_UNDO,\r\n      this.onAfterUndoEventListener\r\n    );\r\n    this.imageEditor._invoker.on(\r\n      eventNames.AFTER_REDO,\r\n      this.onAfterRedoEventListener\r\n    );\r\n\r\n    if (this.initialImage != null) {\r\n      this.onLoad(this.initialImage)\r\n    }\r\n  }\r\n\r\n  destroyImageEditor() {\r\n    console.log('DISPOSING IMAGE EDITOR...');\r\n    if (this.imageEditor != null) {\r\n      this.imageEditor.off(\r\n        eventNames.OBJECT_ACTIVATED,\r\n        this.onObjectActivatedEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.EXECUTE_COMMAND,\r\n        this.onExecuteCommandEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.AFTER_UNDO,\r\n        this.onAfterUndoEventListener\r\n      );\r\n      this.imageEditor._invoker.off(\r\n        eventNames.AFTER_REDO,\r\n        this.onAfterRedoEventListener\r\n      );\r\n      const canvas = this.imageEditor._graphics._canvas;\r\n      this.imageEditor.destroy();\r\n      canvas.dispose();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    var that = this;\r\n    this.loadBtn.nativeElement.style.zIndex = '1'\r\n    this.imageContainer.nativeElement.style.zIndex = '-1'\r\n\r\n    setTimeout(() => {\r\n      //   this.imageEditor.on(eventNames.SELECTION_CLEARED, function () {\r\n      //     that.activeObjectId = null;\r\n      //     if (that.submenu === 'text') {\r\n      //       that.imageEditor.changeCursor('text');\r\n      //     } else if (that.submenu !== 'draw' && that.submenu !== 'crop') {\r\n      //       that.imageEditor.stopDrawingMode();\r\n      //     }\r\n      //   });\r\n      that.initializeImageEditor();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.initializeImgUrl != null) {\r\n      URL.revokeObjectURL(this.initializeImgUrl);\r\n    }\r\n    this.destroyImageEditor();\r\n    this.historyServiceSubscription?.unsubscribe();\r\n  }\r\n\r\n  private onObjectActivated(props) {\r\n    console.debug(props);\r\n    this.activeObjectId = props?.id;\r\n    if (props?.id != null) {\r\n      if (\r\n        [\r\n          objectTypes.shapeRect,\r\n          objectTypes.shapeCircle,\r\n          objectTypes.shapeTriangle,\r\n        ].indexOf(props.type) > -1\r\n      ) {\r\n        this.showMenu('shape', false);\r\n      } else if (\r\n        props.type === objectTypes.line ||\r\n        props.type === objectTypes.straightLine\r\n      ) {\r\n        this.showMenu('draw', false);\r\n      } else if (\r\n        props.type === objectTypes.itext ||\r\n        props.type === objectTypes.text\r\n      ) {\r\n        this.showMenu('text', false);\r\n      } else if (props.type === objectTypes.icon) {\r\n        this.showMenu('icon', false);\r\n      } else if (props.type === objectTypes.image) {\r\n        this.showMenu('mask', false);\r\n      }\r\n    }\r\n  }\r\n\r\n  private onExecuteCommand(command: string | Command) {\r\n    if (!isSilentCommand(command)) {\r\n      this.historyService.add(command, this.imageEditor);\r\n    }\r\n  }\r\n\r\n  private onAfterUndo() {\r\n    this.historyService.prev();\r\n  }\r\n\r\n  private onAfterRedo() {\r\n    this.historyService.next();\r\n  }\r\n\r\n  onLoad(event:any){\r\n    this.loadBtn.nativeElement.style.zIndex = '-1'\r\n    this.imageContainer.nativeElement.style.zIndex = '1'\r\n    this.loadImage(event);\r\n  }\r\n\r\n  loadImage(file: string | File | Blob) {\r\n    const type=(<any>file)?.name?.split('.').pop();\r\n    if(type?.toLowerCase()==='heic'){\r\n      heic2any({blob:<Blob>file}).then(data=>{\r\n        file=<Blob>data;\r\n        this.uploadIMage(file);\r\n      }).catch(err=>{\r\n        console.log(\"Err\",err)\r\n      })\r\n    }else{\r\n      this.uploadIMage(file);\r\n    } \r\n  }\r\n\r\n  uploadIMage(file:string | File | Blob){\r\n    if (file != null) {\r\n      let imageUrl: string = null;\r\n      if (typeof file === 'string') {\r\n        imageUrl = file;\r\n      } else {\r\n        if (!isFileApiSupported()) {\r\n          alert('This browser does not support file-api');\r\n          return;\r\n        }\r\n        imageUrl = URL.createObjectURL(file);\r\n      }\r\n\r\n      if (this.initializeImgUrl != null && imageUrl != this.initializeImgUrl) {\r\n        URL.revokeObjectURL(this.initializeImgUrl);\r\n      }\r\n\r\n      this.initializeImgUrl = imageUrl;\r\n      this.imageEditor\r\n        .loadImageFromURL(this.initializeImgUrl, 'RandomFileName')\r\n        .then((sizeValue: ImageSize) => {\r\n          this.imageChosen = true;\r\n          this.showMenu('draw',false);\r\n          this.exitCropOnAction();\r\n          this.imageEditor.clearUndoStack();\r\n          this.imageEditor.clearRedoStack();\r\n          this.historyService.clear();\r\n          this.imageEditor._invoker.fire(\r\n            eventNames.EXECUTE_COMMAND,\r\n            historyNames.LOAD_IMAGE\r\n          );\r\n        })\r\n        ['catch']((message) => Promise.reject(message));\r\n    }\r\n  }\r\n\r\n  resetImage() {\r\n    if (this.initializeImgUrl != null) {\r\n      this.loadImage(this.initializeImgUrl);\r\n    }\r\n  }\r\n\r\n  getImage(\r\n    options: {\r\n      format: 'jpeg' | 'png';\r\n      quality: number;\r\n      multiplier: number;\r\n      left?: number;\r\n      top?: number;\r\n      width?: number;\r\n      height?: number;\r\n    } = {\r\n      format: 'png',\r\n      quality: 1,\r\n      multiplier: 1,\r\n    }\r\n  ): string {\r\n    if (this.imageChosen) {\r\n      return this.imageEditor.toDataURL(options);\r\n    }\r\n    return null;\r\n  }\r\n\r\n  exitCropOnAction() {\r\n    this.hideMenu('crop');\r\n  }\r\n\r\n  hideMenu(\r\n    menuName:\r\n      | 'crop'\r\n      | 'flip'\r\n      | 'rotate'\r\n      | 'filter'\r\n      | 'text'\r\n      | 'icon'\r\n      | 'shape'\r\n      | 'draw'\r\n      | 'mask'\r\n      | null\r\n  ) {\r\n    if (this.submenu == menuName) {\r\n      this.submenu = null;\r\n      this.showSubmenu=false;\r\n      clearSelection(this.imageEditor);\r\n      this.imageEditor.stopDrawingMode();\r\n    }\r\n  }\r\n\r\n  onActiveHistoryElementChanged(items: HistoryItem[]) {\r\n    let rotationEvents = items.filter((i) => i.type === HistoryItemType.Rotate);\r\n    if (rotationEvents.length > 0) {\r\n      let lastRotationEvent = rotationEvents[rotationEvents.length - 1];\r\n      this.rotation = lastRotationEvent.args[0];\r\n    } else {\r\n      this.rotation = 0;\r\n    }\r\n  }\r\n\r\n  showMenu(\r\n    menuName:\r\n      | 'crop'\r\n      | 'flip'\r\n      | 'rotate'\r\n      | 'filter'\r\n      | 'text'\r\n      | 'icon'\r\n      | 'shape'\r\n      | 'draw'\r\n      | 'mask'\r\n      | null,\r\n    discardSelection: boolean = true\r\n  ) {\r\n    this.submenu = menuName;\r\n    this.showSubmenu=true;\r\n    if (discardSelection) {\r\n      clearSelection(this.imageEditor);\r\n    }\r\n    this.imageEditor.stopDrawingMode();\r\n    //this.stopShape();\r\n    // this._changeMenu(menuName, toggle, discardSelection);\r\n\r\n    // if (this.submenu == 'draw') {\r\n    //   this.setDrawMode('free', {\r\n    //     width: this.drawStrokeWidthValue,\r\n    //     color: this.drawStrokeColor,\r\n    //   });\r\n    // }\r\n  }\r\n}\r\n","<div *ngIf=\"template==='default';else newImageEditor\"\r\n  class=\"tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-justify-content-center tui-image-editor-h-100 tui-image-editor-w-100 tui-image-editor-container\">\r\n  <div\r\n    class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-justify-content-center tui-image-editor-align-items-center\">\r\n    <div\r\n      class=\"tui-image-editor-help-menu tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-align-items-center tui-image-editor-justify-content-center tui-image-editor-p-1\">\r\n      <div></div>\r\n      <!-- <div #loadBtn style=\"position: absolute;\"\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-load (loadImage)=\"loadImage($event)\"></tui-image-editor-menus-buttons-load>\r\n        <tui-image-editor-menus-buttons-download [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-download>\r\n      </div> -->\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-zoom-in [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-in>\r\n        <tui-image-editor-menus-buttons-zoom-out [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-out>\r\n        <tui-image-editor-menus-buttons-drag [imageChosen]=\"imageChosen\"\r\n          [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-drag>\r\n      </div>\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-history [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-history>\r\n        <tui-image-editor-menus-buttons-undo [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-undo>\r\n        <tui-image-editor-menus-buttons-redo [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-redo>\r\n        <tui-image-editor-menus-buttons-reset [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"\r\n          (resetImage)=\"resetImage()\"></tui-image-editor-menus-buttons-reset>\r\n      </div>\r\n      <div\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-delete [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-delete>\r\n        <tui-image-editor-menus-buttons-delete-all [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n          (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-delete-all>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- <div #imageContainer\r\n    class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\"\r\n    [style.height]=\"'0'\"></div> -->\r\n    <div style=\"position: relative;height: 100%; display: flex; justify-content: center; align-items: center;\">\r\n      <div #loadBtn style=\"position: absolute;\"\r\n        class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n        <tui-image-editor-menus-buttons-load (loadImage)=\"onLoad($event)\"></tui-image-editor-menus-buttons-load>\r\n      </div>\r\n      <div style=\"position: absolute;height: 100%; width: 100%;\" #imageContainer\r\n        class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\">\r\n      </div>\r\n    </div>\r\n  <div class=\"tui-image-editor-submenu\" *ngIf=\"submenu != null\">\r\n    <tui-image-editor-submenus-crop *ngIf=\"submenu == 'crop'\" [imageEditor]=\"imageEditor\"\r\n      (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-submenus-crop>\r\n    <tui-image-editor-submenus-flip *ngIf=\"submenu == 'flip'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-flip>\r\n    <tui-image-editor-submenus-rotate *ngIf=\"submenu == 'rotate'\" [imageEditor]=\"imageEditor\"\r\n      [(rotation)]=\"rotation\"></tui-image-editor-submenus-rotate>\r\n    <tui-image-editor-submenus-draw *ngIf=\"submenu == 'draw'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-draw>\r\n    <tui-image-editor-submenus-shape *ngIf=\"submenu == 'shape'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-shape>\r\n    <tui-image-editor-submenus-icon *ngIf=\"submenu == 'icon'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-icon>\r\n    <tui-image-editor-submenus-text *ngIf=\"submenu == 'text'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-text>\r\n    <tui-image-editor-submenus-mask *ngIf=\"submenu == 'mask'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-mask>\r\n    <tui-image-editor-submenus-filter *ngIf=\"submenu == 'filter'\"\r\n      [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-filter>\r\n  </div>\r\n  <div\r\n    class=\"tui-image-editor-controls tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-justify-content-center\">\r\n    <div\r\n      class=\"tui-image-editor-menu tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap tui-image-editor-align-items-center\">\r\n      <tui-image-editor-menus-buttons-crop [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'crop'\"\r\n        (clicked)=\"submenu == 'crop' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-crop>\r\n      <tui-image-editor-menus-buttons-flip [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'flip'\"\r\n        (clicked)=\"submenu == 'flip' ? hideMenu($event) : showMenu($event)\">\r\n      </tui-image-editor-menus-buttons-flip>\r\n      <tui-image-editor-menus-buttons-rotate [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'rotate'\"\r\n        (clicked)=\"submenu == 'rotate' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-rotate>\r\n      <tui-image-editor-menus-buttons-draw [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'draw'\"\r\n        (clicked)=\"submenu == 'draw' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-draw>\r\n      <tui-image-editor-menus-buttons-shape [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'shape'\"\r\n        (clicked)=\"submenu == 'shape' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-shape>\r\n      <tui-image-editor-menus-buttons-icon [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'icon'\"\r\n        (clicked)=\"submenu == 'icon' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-icon>\r\n      <tui-image-editor-menus-buttons-text [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'text'\"\r\n        (clicked)=\"submenu == 'text' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-text>\r\n      <tui-image-editor-menus-buttons-mask [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'mask'\"\r\n        (clicked)=\"submenu == 'mask' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-mask>\r\n      <tui-image-editor-menus-buttons-filter [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'filter'\"\r\n        (clicked)=\"submenu == 'filter' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-filter>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #newImageEditor>\r\n  <div class=\"new-template tui-image-editor-container\">\r\n    <div class=\"image-load-container\">\r\n      <div style=\"position: relative;height: 100%; display: flex; justify-content: center; align-items: center;\">\r\n        <div #loadBtn style=\"position: absolute;\"\r\n          class=\"tui-image-editor-help-menu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap\">\r\n          <tui-image-editor-menus-buttons-load (loadImage)=\"onLoad($event)\"></tui-image-editor-menus-buttons-load>\r\n        </div>\r\n        <div style=\"position: absolute;height: 100%; width: 100%;\" #imageContainer\r\n          class=\"tui-image-editor-flex-grow-1 tui-image-editor-d-flex tui-image-editor-align-items-center tui-image-editor-justify-content-center\">\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"tools-container\" style=\"position: relative;\" [style.width.px]=\"isMenuExpanded ? 160 : 80\">\r\n      <div class=\"primary-tools\">\r\n        <div class=\"selected-option\" style=\"cursor: pointer;\" (click)=\"showSubmenu=!showSubmenu\">\r\n          <svg *ngIf=\"!showSubmenu\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path opacity=\"0.7\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n              d=\"M9.3809 2.67601H17.0011C17.5527 2.67601 18 3.12327 18 3.67491C18 4.22654 17.5527 4.6738 17.0011 4.6738H9.38083C8.94507 6.20757 7.53168 7.33419 5.86014 7.33419C4.18856 7.33419 2.77524 6.20757 2.33944 4.6738H0.998897C0.447224 4.6738 0 4.22651 0 3.67487C0 3.12323 0.447224 2.67597 0.998897 2.67601H2.33951C2.77527 1.14224 4.18863 0.015625 5.86021 0.015625C7.53175 0.015625 8.9451 1.14224 9.3809 2.67601ZM4.19868 3.67484C4.19868 4.59097 4.944 5.33632 5.86017 5.33632C6.77635 5.33632 7.52166 4.59097 7.52166 3.67484C7.52166 2.7587 6.77635 2.01335 5.86017 2.01335C4.944 2.01335 4.19868 2.7587 4.19868 3.67484ZM15.6581 11.3275H17.0011C17.5528 11.3275 18 11.7748 18 12.3264C18 12.8781 17.5528 13.3253 17.0011 13.3253H15.6581C15.2224 14.8591 13.809 15.9857 12.1374 15.9857C10.4659 15.9857 9.05254 14.8591 8.61674 13.3253H0.998897C0.447224 13.3253 0 12.8781 0 12.3264C0 11.7748 0.447224 11.3275 0.998897 11.3275H8.61674C9.05251 9.79378 10.4659 8.66716 12.1374 8.66716C13.809 8.66716 15.2223 9.79378 15.6581 11.3275ZM10.476 12.3264C10.476 13.2426 11.2213 13.9879 12.1374 13.9879C13.0536 13.9879 13.799 13.2426 13.7989 12.3264C13.7989 11.4103 13.0536 10.665 12.1374 10.665C11.2213 10.665 10.476 11.4103 10.476 12.3264Z\"\r\n              fill=\"#25282B\" />\r\n          </svg>\r\n          <svg *ngIf=\"showSubmenu\" width=\"42\" height=\"40\" viewBox=\"0 0 42 40\" fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <rect width=\"42\" height=\"40\" rx=\"8\" fill=\"#25282B\" fill-opacity=\"0.1\" />\r\n            <g opacity=\"0.7\">\r\n              <path\r\n                d=\"M16.1375 25.9935C15.8433 26.0108 15.554 25.9119 15.3305 25.7176C14.8898 25.2691 14.8898 24.5447 15.3305 24.0962L24.9801 14.3337C25.4384 13.8998 26.1576 13.9239 26.5865 14.3876C26.9744 14.807 26.997 15.4515 26.6395 15.8976L16.9331 25.7176C16.7125 25.9091 16.4278 26.0078 16.1375 25.9935Z\"\r\n                fill=\"#25282B\" />\r\n              <path\r\n                d=\"M25.7732 25.9938C25.475 25.9925 25.1893 25.8728 24.9776 25.6603L15.328 15.8978C14.9197 15.4155 14.9752 14.6896 15.452 14.2765C15.8775 13.9078 16.5051 13.9078 16.9306 14.2765L26.637 24.039C27.0952 24.473 27.1189 25.2007 26.6899 25.6643C26.6728 25.6827 26.6552 25.7006 26.637 25.7178C26.3993 25.9269 26.0865 26.0268 25.7732 25.9938Z\"\r\n                fill=\"#25282B\" />\r\n            </g>\r\n          </svg>\r\n        </div>\r\n        <div class=\"hr\">\r\n\r\n        </div>\r\n        <div class=\"menu\">\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-draw #penMenu [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'draw'\"\r\n              (clicked)=\"submenu == 'draw' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-draw>\r\n          </div>\r\n          <!-- <div class=\"eraser\">\r\n  \r\n          </div> -->\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-text [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'text'\"\r\n              (clicked)=\"submenu == 'text' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-text>\r\n          </div>\r\n          <div class=\"tool-icon-group\">\r\n            <tui-image-editor-menus-buttons-zoom-in [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-in>\r\n            <tui-image-editor-menus-buttons-zoom-out [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-zoom-out>\r\n            <tui-image-editor-menus-buttons-drag [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-drag>\r\n          </div>\r\n          <div class=\"tool-icon-group\">\r\n            <tui-image-editor-menus-buttons-history\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-history>\r\n            <tui-image-editor-menus-buttons-undo [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-undo>\r\n            <tui-image-editor-menus-buttons-redo [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-menus-buttons-redo>\r\n            <tui-image-editor-menus-buttons-reset [imageChosen]=\"imageChosen\" [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"\r\n              (resetImage)=\"resetImage()\"></tui-image-editor-menus-buttons-reset>\r\n          </div>\r\n\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-crop [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'crop'\"\r\n              (clicked)=\"submenu == 'crop' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-crop>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-flip [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'flip'\"\r\n              (clicked)=\"submenu == 'flip' ? hideMenu($event) : showMenu($event)\">\r\n            </tui-image-editor-menus-buttons-flip>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-rotate [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'rotate'\"\r\n              (clicked)=\"submenu == 'rotate' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-rotate>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-shape [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'shape'\"\r\n              (clicked)=\"submenu == 'shape' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-shape>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-icon [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'icon'\"\r\n              (clicked)=\"submenu == 'icon' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-icon>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-mask [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'mask'\"\r\n              (clicked)=\"submenu == 'mask' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-mask>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-filter [imageChosen]=\"imageChosen\" [selected]=\"submenu == 'filter'\"\r\n              (clicked)=\"submenu == 'filter' ? hideMenu($event) : showMenu($event)\"></tui-image-editor-menus-buttons-filter>\r\n          </div>\r\n          <div class=\"tool-icon\">\r\n            <tui-image-editor-menus-buttons-download [imageChosen]=\"imageChosen\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-menus-buttons-download>\r\n          </div>\r\n        </div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n        <div class=\"sub-menu\">\r\n          <div class=\"tui-image-editor-submenu new\" [style.right.px]=\"isMenuExpanded ? 160 : 80\"\r\n            *ngIf=\"submenu != null && showSubmenu\">\r\n            <tui-image-editor-submenus-crop *ngIf=\"submenu == 'crop'\" [imageEditor]=\"imageEditor\"\r\n              (cancelCroppingRequested)=\"exitCropOnAction()\"></tui-image-editor-submenus-crop>\r\n            <tui-image-editor-submenus-flip *ngIf=\"submenu == 'flip'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-flip>\r\n            <tui-image-editor-submenus-rotate *ngIf=\"submenu == 'rotate'\" [imageEditor]=\"imageEditor\"\r\n              [(rotation)]=\"rotation\"></tui-image-editor-submenus-rotate>\r\n            <tui-image-editor-submenus-draw *ngIf=\"submenu == 'draw'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-draw>\r\n            <tui-image-editor-submenus-shape *ngIf=\"submenu == 'shape'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-shape>\r\n            <tui-image-editor-submenus-icon *ngIf=\"submenu == 'icon'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-icon>\r\n            <tui-image-editor-submenus-text *ngIf=\"submenu == 'text'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-text>\r\n            <tui-image-editor-submenus-mask *ngIf=\"submenu == 'mask'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-mask>\r\n            <tui-image-editor-submenus-filter *ngIf=\"submenu == 'filter'\"\r\n              [imageEditor]=\"imageEditor\"></tui-image-editor-submenus-filter>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"toggler\" (click)=\"isMenuExpanded=!isMenuExpanded\" style=\"cursor: pointer;\">\r\n        <svg *ngIf=\"!isMenuExpanded\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n          xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n            d=\"M0.864575 7.34425C0.503475 7.70535 0.503475 8.29473 0.864575 8.65583L7.93771 15.7287C8.29937 16.0904 8.88768 16.0904 9.2493 15.7287L9.64494 15.3331C10.0069 14.9711 10.007 14.3831 9.64498 14.0211L4.27939 8.65599C3.91733 8.29401 3.91733 7.7059 4.27939 7.34393L9.64494 1.97882C10.007 1.6168 10.007 1.02885 9.6449 0.66683L9.24926 0.27119C8.88816 -0.0899105 8.29877 -0.0899105 7.93767 0.27119L0.864575 7.34425ZM15.4293 0.27111C15.7907 -0.0903898 16.3796 -0.0903499 16.741 0.27111L17.1367 0.66675C17.498 1.02805 17.498 1.61744 17.1367 1.97878L11.7714 7.34393C11.4094 7.70595 11.4094 8.29398 11.7714 8.65599L17.1367 14.0211C17.4982 14.3825 17.4981 14.9717 17.1367 15.3331L16.7411 15.7288C16.3795 16.0904 15.7909 16.0904 15.4293 15.7288L8.98444 9.28372C7.17658 11.0898 7.63387 10.6318 8.98312 9.2824L8.35659 8.65583C7.99525 8.29449 7.99529 7.70554 8.35659 7.34421L15.4293 0.27111Z\"\r\n            fill=\"#515355\" />\r\n        </svg>\r\n        <svg *ngIf=\"isMenuExpanded\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\"\r\n          xmlns=\"http://www.w3.org/2000/svg\">\r\n          <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n            d=\"M17.1354 8.65575C17.4965 8.29465 17.4965 7.70527 17.1354 7.34417L10.0623 0.27127C9.70063 -0.0903886 9.11232 -0.0903885 8.7507 0.271271L8.35506 0.666911C7.99308 1.02889 7.993 1.61688 8.35502 1.97894L13.7206 7.34401C14.0827 7.70599 14.0827 8.2941 13.7206 8.65607L8.35506 14.0212C7.993 14.3832 7.99304 14.9712 8.3551 15.3332L8.75074 15.7288C9.11184 16.0899 9.70123 16.0899 10.0623 15.7288L17.1354 8.65575ZM2.57075 15.7289C2.20929 16.0904 1.62042 16.0904 1.25896 15.7289L0.863319 15.3333C0.50202 14.972 0.50198 14.3826 0.863319 14.0212L6.22863 8.65607C6.59065 8.29406 6.59065 7.70603 6.22863 7.34401L0.86328 1.9789C0.50182 1.61748 0.50186 1.02829 0.86328 0.666871L1.25892 0.27123C1.62054 -0.0903879 2.20909 -0.090428 2.57071 0.27123L9.01556 6.71628C10.8234 4.91023 10.3661 5.36824 9.01688 6.7176L9.64341 7.34417C10.0047 7.70551 10.0047 8.29446 9.64341 8.6558L2.57075 15.7289Z\"\r\n            fill=\"#515355\" />\r\n        </svg>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}
|