UNPKG

truly-ui

Version:

Web Components for Desktop Applications.

131 lines 17 kB
import { CurrencyService } from './currency.service'; export class CurrencyHandler { get inputService() { return this._inputService; } set inputService(value) { this._inputService = value; } constructor(htmlInputElement, options) { this.inputService = new CurrencyService(htmlInputElement, options); } handleCut(event) { setTimeout(() => { this.inputService.updateFieldValue(); this.setValue(this.inputService.value); this.onModelChange(this.inputService.value); }, 0); } handleInput(event) { const keyCode = this.inputService.rawValue.charCodeAt(this.inputService.rawValue.length - 1); const rawValueLength = this.inputService.rawValue.length; const rawValueSelectionEnd = this.inputService.inputSelection.selectionEnd; const storedRawValueLength = this.inputService.storedRawValue.length; this.inputService.rawValue = this.inputService.storedRawValue; if (rawValueLength !== rawValueSelectionEnd || Math.abs(rawValueLength - storedRawValueLength) !== 1) { this.setCursorPosition(event); return; } if (rawValueLength < storedRawValueLength) { this.inputService.removeNumber(8); } if (rawValueLength > storedRawValueLength) { switch (keyCode) { case 43: this.inputService.changeToPositive(); break; case 45: this.inputService.changeToNegative(); break; default: if (!this.inputService.canInputMoreNumbers) { return; } this.inputService.addNumber(keyCode); } } this.setCursorPosition(event); this.onModelChange(this.inputService.value); } handleKeydown(event) { const keyCode = event.which || event.charCode || event.keyCode; if (keyCode === 8 || keyCode === 46 || keyCode === 63272) { event.preventDefault(); const selectionRangeLength = Math.abs(this.inputService.inputSelection.selectionEnd - this.inputService.inputSelection.selectionStart); if (selectionRangeLength === 0) { this.inputService.removeNumber(keyCode); this.onModelChange(this.inputService.value); } if (selectionRangeLength >= (this.inputService.rawValue.length - this.inputService.prefixLength())) { this.clearValue(); } } } clearValue() { this.setValue(this.inputService.isNullable() ? null : 0); this.onModelChange(this.inputService.value); } handleKeypress(event) { const keyCode = event.which || event.charCode || event.keyCode; if (keyCode === 97 && event.ctrlKey) { return; } switch (keyCode) { case undefined: case 9: case 13: case 37: case 39: return; case 43: this.inputService.changeToPositive(); break; case 45: this.inputService.changeToNegative(); break; default: if (this.inputService.canInputMoreNumbers) { const selectionRangeLength = Math.abs(this.inputService.inputSelection.selectionEnd - this.inputService.inputSelection.selectionStart); if (selectionRangeLength === this.inputService.rawValue.length) { this.setValue(0); } this.inputService.addNumber(keyCode); } } event.preventDefault(); this.onModelChange(this.inputService.value); } handlePaste(event) { setTimeout(() => { this.inputService.updateFieldValue(); this.setValue(this.inputService.value); this.onModelChange(this.inputService.value); }, 1); } updateOptions(options) { this.inputService.updateOptions(options); } getOnModelChange() { return this.onModelChange; } setOnModelChange(callbackFunction) { this.onModelChange = callbackFunction; } getOnModelTouched() { return this.onModelTouched; } setOnModelTouched(callbackFunction) { this.onModelTouched = callbackFunction; } setValue(value) { this.inputService.value = value; } setCursorPosition(event) { setTimeout(function () { event.target.setSelectionRange(event.target.value.length, event.target.value.length); }, 0); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency.handler.js","sourceRoot":"","sources":["../../../../../../projects/truly-ui/src/components/input/directives/currency/currency.handler.ts"],"names":[],"mappings":"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","sourcesContent":["import {CurrencyService} from './currency.service';\n\nexport class CurrencyHandler {\n\n  private _inputService: CurrencyService;\n  private onModelChange: Function;\n  private onModelTouched: Function;\n\n  get inputService() {\n    return this._inputService;\n  }\n\n  set inputService( value: CurrencyService ) {\n    this._inputService = value;\n  }\n\n  constructor(htmlInputElement: HTMLInputElement, options: any) {\n    this.inputService = new CurrencyService(htmlInputElement, options);\n  }\n\n  handleCut(event: any): void {\n    setTimeout(() => {\n      this.inputService.updateFieldValue();\n      this.setValue(this.inputService.value);\n      this.onModelChange(this.inputService.value);\n    }, 0);\n  }\n\n  handleInput(event: any): void {\n    const keyCode = this.inputService.rawValue.charCodeAt(this.inputService.rawValue.length - 1);\n    const rawValueLength = this.inputService.rawValue.length;\n    const rawValueSelectionEnd = this.inputService.inputSelection.selectionEnd;\n    const storedRawValueLength = this.inputService.storedRawValue.length;\n    this.inputService.rawValue = this.inputService.storedRawValue;\n\n    if (rawValueLength !== rawValueSelectionEnd || Math.abs(rawValueLength - storedRawValueLength) !== 1) {\n      this.setCursorPosition(event);\n      return;\n    }\n\n    if (rawValueLength < storedRawValueLength) {\n      this.inputService.removeNumber(8);\n    }\n\n    if (rawValueLength > storedRawValueLength) {\n      switch (keyCode) {\n        case 43:\n          this.inputService.changeToPositive();\n          break;\n        case 45:\n          this.inputService.changeToNegative();\n          break;\n        default:\n          if (!this.inputService.canInputMoreNumbers) {\n            return;\n          }\n\n          this.inputService.addNumber(keyCode);\n      }\n    }\n\n    this.setCursorPosition(event);\n    this.onModelChange(this.inputService.value);\n  }\n\n  handleKeydown(event: any): void {\n    const keyCode = event.which || event.charCode || event.keyCode;\n\n    if (keyCode === 8 || keyCode === 46 || keyCode === 63272) {\n      event.preventDefault();\n      const selectionRangeLength = Math.abs(this.inputService.inputSelection.selectionEnd\n        - this.inputService.inputSelection.selectionStart);\n\n      if (selectionRangeLength === 0) {\n        this.inputService.removeNumber(keyCode);\n        this.onModelChange(this.inputService.value);\n      }\n\n      if (selectionRangeLength >= (this.inputService.rawValue.length - this.inputService.prefixLength())) {\n        this.clearValue();\n      }\n    }\n  }\n\n  clearValue() {\n    this.setValue(this.inputService.isNullable() ? null : 0);\n    this.onModelChange(this.inputService.value);\n  }\n\n  handleKeypress(event: any): void {\n    const keyCode = event.which || event.charCode || event.keyCode;\n\n    if (keyCode === 97 && event.ctrlKey) {\n      return;\n    }\n\n    switch (keyCode) {\n      case undefined:\n      case 9:\n      case 13:\n      case 37:\n      case 39:\n        return;\n      case 43:\n        this.inputService.changeToPositive();\n        break;\n      case 45:\n        this.inputService.changeToNegative();\n        break;\n      default:\n        if (this.inputService.canInputMoreNumbers) {\n          const selectionRangeLength = Math.abs(this.inputService.inputSelection.selectionEnd\n            - this.inputService.inputSelection.selectionStart);\n\n          if (selectionRangeLength === this.inputService.rawValue.length) {\n            this.setValue(0);\n          }\n\n          this.inputService.addNumber(keyCode);\n        }\n    }\n\n    event.preventDefault();\n    this.onModelChange(this.inputService.value);\n  }\n\n  handlePaste(event: any): void {\n    setTimeout(() => {\n      this.inputService.updateFieldValue();\n      this.setValue(this.inputService.value);\n      this.onModelChange(this.inputService.value);\n    }, 1);\n  }\n\n  updateOptions(options: any): void {\n    this.inputService.updateOptions(options);\n  }\n\n  getOnModelChange(): Function {\n    return this.onModelChange;\n  }\n\n  setOnModelChange(callbackFunction: Function): void {\n    this.onModelChange = callbackFunction;\n  }\n\n  getOnModelTouched(): Function {\n    return this.onModelTouched;\n  }\n\n  setOnModelTouched(callbackFunction: Function) {\n    this.onModelTouched = callbackFunction;\n  }\n\n  setValue(value: number): void {\n    this.inputService.value = value;\n  }\n\n  private setCursorPosition(event: any): void {\n    setTimeout(function () {\n      event.target.setSelectionRange(event.target.value.length, event.target.value.length);\n    }, 0);\n  }\n}\n"]}