asksuite-citrus 1.13.5 → 1.14.6-beta.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.
@@ -10,8 +10,7 @@ export class RichtextWrapper {
10
10
  .pipe(map(() => this.quill.root.innerHTML));
11
11
  }
12
12
  get listenOnTouched$() {
13
- return fromEvent(this.quill, 'selection-change')
14
- .pipe(map(() => !this.quill.getSelection(false)));
13
+ return fromEvent(this.quill, 'selection-change').pipe(filter(() => Boolean(this.quill.getSelection(false))), map(() => null));
15
14
  }
16
15
  get listenEscape$() {
17
16
  return this.esc$.asObservable();
@@ -301,4 +300,4 @@ export const QuillProxy = {
301
300
  export const RichtextWrapperProxy = {
302
301
  RichtextWrapper
303
302
  };
304
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-wrapper.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/richtext-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, NgZone } from '@angular/core';\nimport Quill, { BoundsStatic, RangeStatic, SelectionChangeHandler, Sources, TextChangeHandler } from 'quill';\nimport { BehaviorSubject, Subject, Subscription, filter, fromEvent, map } from 'rxjs';\nimport {\n  RichTextFunctions,\n  RichtextFormats,\n  Tool,\n  ToolKeys,\n  ToolsState,\n} from '../interfaces/richtext-toolbox.interface';\nimport { URL_REGEX } from '../constants/url-regex.constant';\n\nexport class RichtextWrapper implements RichTextFunctions {\n  private quill!: Quill;\n  private stateSub = new BehaviorSubject<ToolsState>({\n    hasSelection: false,\n    hasFocus: false,\n    formats: {\n      italic: false,\n      bold: false,\n      underline: false,\n      strike: false,\n      link: '',\n      list_bulleted: false,\n      list_numbered: false,\n      justify_left: false,\n      justify_center: false,\n      justify_right: false,\n    },\n    disabledTools: []\n  });\n  private esc$ = new Subject<boolean>();\n  private enter$ = new Subject<boolean>();\n  private maxLength = -1;\n  private breakOnEnter = false;\n\n  private textChangeHandler: TextChangeHandler = () => {\n    this.update();\n  };\n\n  private selectionChangeHandler: SelectionChangeHandler = (\n    value: RangeStatic,\n    oldRange: RangeStatic,\n    source: Sources\n  ) => {\n    this.update();\n  };\n\n  private bindings = {\n    bold: {\n      handler: () => {\n        this.setBold();\n        return false;\n      },\n    },\n    italic: {\n      handler: () => {\n        this.setItalic();\n        return false;\n      },\n    },\n    underline: {\n      handler: () => {\n        this.setUnderline();\n        return false;\n      },\n    },\n    escape:{\n      key: 'escape',\n      handler: () => {\n        this.esc$.next(true);\n        return false;\n      }\n    },\n    enter: {\n      key: 'enter',\n      handler: () => {\n        this.enter$.next(true);\n        return this.breakOnEnter;\n      }\n    }\n\n  };\n  private maxLengthSubscription?: Subscription;\n\n  public get state(){\n      return this.stateSub.value\n  }\n  \n  public state$ = this.stateSub.asObservable();\n    \n  public get listenTextChanges$(){\n    return fromEvent(this.quill, 'text-change')\n      .pipe(map(() => this.quill.root.innerHTML)); \n  }\n\n  public get listenOnTouched$(){\n    return fromEvent(this.quill, 'selection-change')\n      .pipe(map(() => !this.quill.getSelection(false)));\n  }\n\n  public get listenEscape$(){\n    return this.esc$.asObservable()\n  }\n\n  public get listenEnter$(){\n    return this.enter$.asObservable();\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private cd: ChangeDetectorRef,\n    private elementRef: ElementRef<HTMLElement>,\n  ) {\n    const editorId = `editor-${new Date().getTime()}`;\n    this.elementRef.nativeElement.setAttribute('id', editorId);\n    this.quill = new QuillProxy.Quill(`#${editorId}`, {\n      placeholder: '',\n      modules: {\n        clipboard: {\n          matchers: [[Node.TEXT_NODE, this.urlMatcher.bind(this)]],\n        },\n        keyboard: { bindings: this.bindings },\n      },\n    });\n    this.listenEditorChanges();\n  }\n\n  public setItalic() {\n    if(this.isToolDisabled('italic')) return;\n    this.quill.format('italic', !this.state.formats.italic);\n    this.update();\n  }\n\n  public setBold() {\n    if(this.isToolDisabled('bold')) return\n    this.quill.format('bold', !this.state.formats.bold);\n    this.update();\n  }\n\n  public setUnderline() {\n    if(this.isToolDisabled('underline')) return;\n    this.quill.format('underline', !this.state.formats.underline);\n    this.update();\n  }\n\n  public setStrike() {\n    if(this.isToolDisabled('strike')) return;\n    this.quill.format('strike', !this.state.formats.strike);\n    this.update();\n  }\n\n  public setListNumbered() {\n    if(this.isToolDisabled('list_numbered')) return;\n    if (this.state.formats.list_numbered)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'ordered');\n    this.update();\n  }\n\n  public setListBulleted() {\n    if(this.isToolDisabled('list_bulleted')) return;\n    if (this.state.formats.list_bulleted)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'bulleted');\n    this.update();\n  }\n\n  public setLink(link: string) {\n    if(this.isToolDisabled('link')) return;\n\n    const range = this.quill.getSelection(true);\n\n    if (range && !range.length) {\n      const [textBloat, offset] = this.quill.getLeaf(range!.index);\n\n      const start = range!.index - offset;\n      const length = textBloat.length();\n\n      this.quill.formatText(start, length, 'link', link);\n    } else {\n      this.quill.format('link', link);\n    }\n\n    this.update();\n  }\n\n  public setJustifyLeft() {\n    if(this.isToolDisabled('justify_left')) return;\n    this.quill.format('align', null);\n    this.update();\n  }\n\n  public setJustifyCenter() {\n    if(this.isToolDisabled('justify_center')) return;\n    this.quill.format('align', 'center');\n    this.update();\n  }\n\n  public setJustifyRight() {\n    if(this.isToolDisabled('justify_right')) return;\n    this.quill.format('align', 'right');\n    this.update();\n  }\n\n  public setRemove() {\n    const selection = this.quill.getSelection();\n    if (selection) this.quill.removeFormat(selection!.index, selection!.length);\n    this.update();\n  }\n\n  public setPlaceholder(placeholder: string){\n    this.quill.root.dataset['placeholder'] = placeholder;\n  }\n\n  public setText(text: string){\n    this.quill.setContents(this.quill.clipboard.convert(text));\n  }\n\n  public setMaxLength(length: number){\n    this.maxLength = length;\n\n    this.maxLengthSubscription?.unsubscribe();\n    if(this.maxLength > 0)\n      this.maxLengthSubscription = \n        fromEvent(this.quill, 'text-change')\n        .pipe(filter(() => this.quill.getLength() > this.maxLength))\n        .subscribe(() => {\n          this.quill.deleteText(this.maxLength, this.quill.getLength());\n      })\n  }\n\n  public setDisabledTools(tools: ToolKeys){\n    if(JSON.stringify(tools) !== JSON.stringify(this.stateSub.value.disabledTools))\n      this.stateSub.next({...this.stateSub.value, disabledTools: tools, })\n  }\n\n  public setEditorClass(className: string){\n    if(!className) return;\n    this.quill.root.classList.add(className);\n  }\n\n  public getEditorElement(){\n    return this.quill.root;\n  }\n\n  public disable(){\n    this.quill.disable();\n  }\n\n  public enable(){\n    this.quill.enable();\n  }\n\n  public focus(){\n    this.quill.focus();\n  }\n\n  public setBreakOnEnter(breakOnEnter: boolean){\n    this.breakOnEnter = breakOnEnter;\n  }\n\n  public destroy() {\n    this.quill.off('selection-change', this.selectionChangeHandler);\n    this.quill.off('text-change', this.textChangeHandler);\n    this.esc$.unsubscribe();\n    this.enter$.unsubscribe();\n    this.stateSub.unsubscribe();\n    this.maxLengthSubscription?.unsubscribe();\n  }\n\n  private isToolDisabled(tool: Tool){\n    return this.stateSub.value.disabledTools.includes(tool)\n  }\n\n  private urlMatcher(node: any, delta: any) {\n    if (typeof node.data !== 'string') return;\n    const matches = node.data.match(URL_REGEX);\n\n    if (matches && matches.length > 0) {\n      let text = '';\n      const selection = this.quill.getSelection(true);\n      if (selection.length)\n        text = this.quill.getText(selection!.index, selection!.length);\n\n      const ops = [];\n      let str = node.data;\n      matches.forEach(function (match: any) {\n        const split = str.split(match);\n        const beforeLink = split.shift();\n        ops.push({ insert: beforeLink });\n        ops.push({ insert: text || match, attributes: { link: match } });\n        str = split.join(match);\n      });\n      ops.push({ insert: str });\n      delta.ops = ops;\n    }\n\n    return delta;\n  }\n\n  private listenEditorChanges() {\n    this.quill.on('selection-change', this.selectionChangeHandler);\n    this.quill.on('text-change', this.textChangeHandler);\n  }\n\n\n  private update() {\n    let bounds: BoundsStatic | undefined;\n    let formatsArr;\n\n    const range = this.quill.getSelection(false);\n    if  (range){ \n      bounds = this.quill.getBounds(range.index, range.length);\n      formatsArr = this.quill.getFormat(range) as any;\n    }\n\n    const formats: RichtextFormats = {\n      italic: formatsArr?.italic || false,\n      bold: formatsArr?.bold || false,\n      underline: formatsArr?.underline || false,\n      strike: formatsArr?.strike || false,\n      link: formatsArr?.link || '',\n      list_bulleted: formatsArr?.list === 'bullet',\n      list_numbered: formatsArr?.list === 'ordered',\n      justify_left: formatsArr?.align === 'left',\n      justify_center: formatsArr?.align === 'center',\n      justify_right: formatsArr?.align === 'right',\n    };\n\n    const hasSelection = !!range?.length;\n    const hasFocus = !!range;\n\n    const newState: ToolsState = { \n      ...this.stateSub.value, \n      hasSelection, \n      formats, \n      bounds, \n      hasFocus \n    };\n\n    this.ngZone.run(() => {\n      this.stateSub.next(newState);\n      this.cd.markForCheck();\n    })\n  }\n}\n\n//to work around testing problems \nexport const QuillProxy ={\n  Quill\n}\n\n//to work around testing problems \nexport const RichtextWrapperProxy = {\n  RichtextWrapper\n}"]}
303
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-wrapper.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/richtext-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, NgZone } from '@angular/core';\nimport Quill, { BoundsStatic, RangeStatic, SelectionChangeHandler, Sources, TextChangeHandler } from 'quill';\nimport { BehaviorSubject, Subject, Subscription, filter, fromEvent, map } from 'rxjs';\nimport {\n  RichTextFunctions,\n  RichtextFormats,\n  Tool,\n  ToolKeys,\n  ToolsState,\n} from '../interfaces/richtext-toolbox.interface';\nimport { URL_REGEX } from '../constants/url-regex.constant';\n\nexport class RichtextWrapper implements RichTextFunctions {\n  private quill!: Quill;\n  private stateSub = new BehaviorSubject<ToolsState>({\n    hasSelection: false,\n    hasFocus: false,\n    formats: {\n      italic: false,\n      bold: false,\n      underline: false,\n      strike: false,\n      link: '',\n      list_bulleted: false,\n      list_numbered: false,\n      justify_left: false,\n      justify_center: false,\n      justify_right: false,\n    },\n    disabledTools: []\n  });\n  private esc$ = new Subject<boolean>();\n  private enter$ = new Subject<boolean>();\n  private maxLength = -1;\n  private breakOnEnter = false;\n\n  private textChangeHandler: TextChangeHandler = () => {\n    this.update();\n  };\n\n  private selectionChangeHandler: SelectionChangeHandler = (\n    value: RangeStatic,\n    oldRange: RangeStatic,\n    source: Sources\n  ) => {\n    this.update();\n  };\n\n  private bindings = {\n    bold: {\n      handler: () => {\n        this.setBold();\n        return false;\n      },\n    },\n    italic: {\n      handler: () => {\n        this.setItalic();\n        return false;\n      },\n    },\n    underline: {\n      handler: () => {\n        this.setUnderline();\n        return false;\n      },\n    },\n    escape:{\n      key: 'escape',\n      handler: () => {\n        this.esc$.next(true);\n        return false;\n      }\n    },\n    enter: {\n      key: 'enter',\n      handler: () => {\n        this.enter$.next(true);\n        return this.breakOnEnter;\n      }\n    }\n\n  };\n  private maxLengthSubscription?: Subscription;\n\n  public get state(){\n      return this.stateSub.value\n  }\n  \n  public state$ = this.stateSub.asObservable();\n    \n  public get listenTextChanges$(){\n    return fromEvent(this.quill, 'text-change')\n      .pipe(map(() => this.quill.root.innerHTML)); \n  }\n\n  public get listenOnTouched$() {\n    return fromEvent(this.quill, 'selection-change').pipe(\n      filter(() => Boolean(this.quill.getSelection(false))),\n      map(() => null)\n    );\n  }\n\n  public get listenEscape$(){\n    return this.esc$.asObservable()\n  }\n\n  public get listenEnter$(){\n    return this.enter$.asObservable();\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private cd: ChangeDetectorRef,\n    private elementRef: ElementRef<HTMLElement>,\n  ) {\n    const editorId = `editor-${new Date().getTime()}`;\n    this.elementRef.nativeElement.setAttribute('id', editorId);\n    this.quill = new QuillProxy.Quill(`#${editorId}`, {\n      placeholder: '',\n      modules: {\n        clipboard: {\n          matchers: [[Node.TEXT_NODE, this.urlMatcher.bind(this)]],\n        },\n        keyboard: { bindings: this.bindings },\n      },\n    });\n    this.listenEditorChanges();\n  }\n\n  public setItalic() {\n    if(this.isToolDisabled('italic')) return;\n    this.quill.format('italic', !this.state.formats.italic);\n    this.update();\n  }\n\n  public setBold() {\n    if(this.isToolDisabled('bold')) return\n    this.quill.format('bold', !this.state.formats.bold);\n    this.update();\n  }\n\n  public setUnderline() {\n    if(this.isToolDisabled('underline')) return;\n    this.quill.format('underline', !this.state.formats.underline);\n    this.update();\n  }\n\n  public setStrike() {\n    if(this.isToolDisabled('strike')) return;\n    this.quill.format('strike', !this.state.formats.strike);\n    this.update();\n  }\n\n  public setListNumbered() {\n    if(this.isToolDisabled('list_numbered')) return;\n    if (this.state.formats.list_numbered)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'ordered');\n    this.update();\n  }\n\n  public setListBulleted() {\n    if(this.isToolDisabled('list_bulleted')) return;\n    if (this.state.formats.list_bulleted)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'bulleted');\n    this.update();\n  }\n\n  public setLink(link: string) {\n    if(this.isToolDisabled('link')) return;\n\n    const range = this.quill.getSelection(true);\n\n    if (range && !range.length) {\n      const [textBloat, offset] = this.quill.getLeaf(range!.index);\n\n      const start = range!.index - offset;\n      const length = textBloat.length();\n\n      this.quill.formatText(start, length, 'link', link);\n    } else {\n      this.quill.format('link', link);\n    }\n\n    this.update();\n  }\n\n  public setJustifyLeft() {\n    if(this.isToolDisabled('justify_left')) return;\n    this.quill.format('align', null);\n    this.update();\n  }\n\n  public setJustifyCenter() {\n    if(this.isToolDisabled('justify_center')) return;\n    this.quill.format('align', 'center');\n    this.update();\n  }\n\n  public setJustifyRight() {\n    if(this.isToolDisabled('justify_right')) return;\n    this.quill.format('align', 'right');\n    this.update();\n  }\n\n  public setRemove() {\n    const selection = this.quill.getSelection();\n    if (selection) this.quill.removeFormat(selection!.index, selection!.length);\n    this.update();\n  }\n\n  public setPlaceholder(placeholder: string){\n    this.quill.root.dataset['placeholder'] = placeholder;\n  }\n\n  public setText(text: string){\n    this.quill.setContents(this.quill.clipboard.convert(text));\n  }\n\n  public setMaxLength(length: number){\n    this.maxLength = length;\n\n    this.maxLengthSubscription?.unsubscribe();\n    if(this.maxLength > 0)\n      this.maxLengthSubscription = \n        fromEvent(this.quill, 'text-change')\n        .pipe(filter(() => this.quill.getLength() > this.maxLength))\n        .subscribe(() => {\n          this.quill.deleteText(this.maxLength, this.quill.getLength());\n      })\n  }\n\n  public setDisabledTools(tools: ToolKeys){\n    if(JSON.stringify(tools) !== JSON.stringify(this.stateSub.value.disabledTools))\n      this.stateSub.next({...this.stateSub.value, disabledTools: tools, })\n  }\n\n  public setEditorClass(className: string){\n    if(!className) return;\n    this.quill.root.classList.add(className);\n  }\n\n  public getEditorElement(){\n    return this.quill.root;\n  }\n\n  public disable(){\n    this.quill.disable();\n  }\n\n  public enable(){\n    this.quill.enable();\n  }\n\n  public focus(){\n    this.quill.focus();\n  }\n\n  public setBreakOnEnter(breakOnEnter: boolean){\n    this.breakOnEnter = breakOnEnter;\n  }\n\n  public destroy() {\n    this.quill.off('selection-change', this.selectionChangeHandler);\n    this.quill.off('text-change', this.textChangeHandler);\n    this.esc$.unsubscribe();\n    this.enter$.unsubscribe();\n    this.stateSub.unsubscribe();\n    this.maxLengthSubscription?.unsubscribe();\n  }\n\n  private isToolDisabled(tool: Tool){\n    return this.stateSub.value.disabledTools.includes(tool)\n  }\n\n  private urlMatcher(node: any, delta: any) {\n    if (typeof node.data !== 'string') return;\n    const matches = node.data.match(URL_REGEX);\n\n    if (matches && matches.length > 0) {\n      let text = '';\n      const selection = this.quill.getSelection(true);\n      if (selection.length)\n        text = this.quill.getText(selection!.index, selection!.length);\n\n      const ops = [];\n      let str = node.data;\n      matches.forEach(function (match: any) {\n        const split = str.split(match);\n        const beforeLink = split.shift();\n        ops.push({ insert: beforeLink });\n        ops.push({ insert: text || match, attributes: { link: match } });\n        str = split.join(match);\n      });\n      ops.push({ insert: str });\n      delta.ops = ops;\n    }\n\n    return delta;\n  }\n\n  private listenEditorChanges() {\n    this.quill.on('selection-change', this.selectionChangeHandler);\n    this.quill.on('text-change', this.textChangeHandler);\n  }\n\n\n  private update() {\n    let bounds: BoundsStatic | undefined;\n    let formatsArr;\n\n    const range = this.quill.getSelection(false);\n    if  (range){ \n      bounds = this.quill.getBounds(range.index, range.length);\n      formatsArr = this.quill.getFormat(range) as any;\n    }\n\n    const formats: RichtextFormats = {\n      italic: formatsArr?.italic || false,\n      bold: formatsArr?.bold || false,\n      underline: formatsArr?.underline || false,\n      strike: formatsArr?.strike || false,\n      link: formatsArr?.link || '',\n      list_bulleted: formatsArr?.list === 'bullet',\n      list_numbered: formatsArr?.list === 'ordered',\n      justify_left: formatsArr?.align === 'left',\n      justify_center: formatsArr?.align === 'center',\n      justify_right: formatsArr?.align === 'right',\n    };\n\n    const hasSelection = !!range?.length;\n    const hasFocus = !!range;\n\n    const newState: ToolsState = { \n      ...this.stateSub.value, \n      hasSelection, \n      formats, \n      bounds, \n      hasFocus \n    };\n\n    this.ngZone.run(() => {\n      this.stateSub.next(newState);\n      this.cd.markForCheck();\n    })\n  }\n}\n\n//to work around testing problems \nexport const QuillProxy ={\n  Quill\n}\n\n//to work around testing problems \nexport const RichtextWrapperProxy = {\n  RichtextWrapper\n}"]}
@@ -7,6 +7,7 @@ import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
7
7
  import { filterSelectedList } from "../../../shared/helpers/filter.helper";
8
8
  import CountryFlagService from "../../../shared/services/country-flag.service";
9
9
  import { NON_DIGIT_REGEX } from "../../../shared/utils/regex";
10
+ import { getCountryFromPhone } from "../../helpers/phone.helper";
10
11
  import * as i0 from "@angular/core";
11
12
  import * as i1 from "@angular/cdk/overlay";
12
13
  import * as i2 from "@angular/common";
@@ -103,7 +104,10 @@ export class PhoneDdiComponent {
103
104
  writeValue(value) {
104
105
  this.value = value;
105
106
  this.inputControl.setValue(value);
106
- this.valueChange.emit(this.value);
107
+ const country = getCountryFromPhone(value);
108
+ if (country) {
109
+ this.selectedFlag = this.countryItems.find(item => item.countryCode === country);
110
+ }
107
111
  }
108
112
  addAvailableFlags(data) {
109
113
  this.countryItems = data;
@@ -164,4 +168,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
164
168
  type: HostListener,
165
169
  args: ["window:click", ['$event']]
166
170
  }] } });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-ddi.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  inject,\n  Input,\n  Output,\n  Provider,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {TemplatePortal} from \"@angular/cdk/portal\";\nimport {Overlay, OverlayRef} from \"@angular/cdk/overlay\";\nimport {debounceTime, map, Subscription} from \"rxjs\";\nimport {AskDropdownDirective} from \"../../directives\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport {filterSelectedList} from \"../../../shared/helpers/filter.helper\";\nimport CountryFlagService from \"../../../shared/services/country-flag.service\";\nimport {CountryData} from \"../../../shared/providers/flag.provider\";\nimport {NON_DIGIT_REGEX} from \"../../../shared/utils/regex\";\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => PhoneDdiComponent),\n};\n\n@Component({\n  selector: 'ask-phone-ddi',\n  templateUrl: './phone-ddi.component.html',\n  styleUrls: ['./phone-ddi.component.scss'],\n  providers: [valueAccessor],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PhoneDdiComponent implements AfterViewInit, ControlValueAccessor {\n  @Input() disabled = false;\n  @Input() value = '';\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\n\n  @ViewChild('phoneContainer') phoneContainer: ElementRef | undefined\n\n  @ViewChild('wrapper') wrapper: ElementRef | undefined\n\n  @ViewChild(\"menuContainer\") menuContainer: ElementRef | undefined\n\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  selectedFlag?: CountryData;\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  protected inputControl = new FormControl({value: '', disabled: this.disabled})\n  protected searchFieldControl = new FormControl(\"\")\n  protected filteredOptions: any[] = []\n  protected isValid = true;\n  private _overlayRef: OverlayRef | undefined;\n  private _portal: TemplatePortal<any> | undefined;\n  private _destroy = inject(DestroyRef)\n  private scrollSub?: Subscription;\n\n  constructor(\n    private change: ChangeDetectorRef,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private countryFlagService: CountryFlagService\n  ) {\n  }\n\n  ngAfterViewInit() {\n    this.countryFlagService.list().subscribe(this.addAvailableFlags.bind(this))\n    this.handleInputChange();\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedFlag = item;\n    this.hideOptions();\n    this.inputControl.setValue('');\n    this.searchFieldControl.setValue('');\n    this.onChange('');\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.change.detectChanges();\n  }\n\n  display(option: any) {\n    return this.displayFn(option)\n  }\n\n  @HostListener(\"window:click\", ['$event'])\n  handleClick(event: MouseEvent) {\n    if (\n      !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.menuContainer?.nativeElement.contains(event.target)) {\n      this.hideOptions()\n    }\n  }\n\n  handleFlagClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n    this.change.detectChanges()\n  }\n\n  showOptions() {\n    this.closed = false\n    if (this.phoneContainer) {\n      this._overlayRef = this.getOverlayConfig(this.phoneContainer)\n\n      this._portal = new TemplatePortal(this.overlayContent!, this.viewContainerRef)\n    }\n\n    this._overlayRef?.attach(this._portal);\n  }\n\n  hideOptions() {\n    this.closed = true;\n    this.searchFieldControl.setValue('')\n    this._overlayRef?.detach()\n    this.change.detectChanges()\n    this.scrollSub?.unsubscribe();\n  }\n\n  onChangePhoneNumber(e: any) {\n    const newValue = e.target.value?.replace(NON_DIGIT_REGEX, '');\n\n    if (this.value !== newValue) {\n      this.onChange(newValue)\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.inputControl.setValue(value);\n    this.valueChange.emit(this.value);\n  }\n\n  protected readonly displayFn = (countryFlag: any) => `${countryFlag.countryName} (${countryFlag.code})`;\n\n  protected readonly filterFn = (search: string) =>\n    filterSelectedList(this.countryItems, search, ['code', 'countryName']);\n\n  private addAvailableFlags(data: CountryData[]) {\n    this.countryItems = data;\n    this.filteredOptions = this.countryItems;\n    this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data);\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.change.detectChanges();\n  }\n\n  private handleInputChange() {\n    this.searchFieldControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      map(value => this.filterFn(value || ''))\n    ).subscribe(items => {\n      this.filteredOptions = items\n    })\n  }\n\n  private getOverlayConfig(wrapper: ElementRef) {\n    return this.overlay.create({\n      width: wrapper.nativeElement.offsetWidth,\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy: this.overlay.position()\n        .flexibleConnectedTo(wrapper.nativeElement)\n        .withPositions([{\n          originX: \"start\",\n          originY: \"bottom\",\n          overlayX: \"start\",\n          overlayY: \"top\",\n        }])\n    });\n  }\n}\n","<div #phoneContainer [style]=\"{cursor: disabled ? 'not-allowed' : 'auto'}\" class=\"phone-ddi\">\n\n  <div\n    #wrapper\n    (click)=\"handleFlagClick()\"\n    *ngIf=\"selectedFlag\"\n    [style]=\"{cursor: !disabled ? 'pointer' : 'not-allowed'}\"\n    class=\"flag\"\n    data-testid=\"flag\">\n\n    <div [style]=\"{backgroundPosition: this.selectedFlag?.backgroundPosition}\" class=\"flag-icon\"></div>\n    <div class=\"flag-arrow\"></div>\n  </div>\n\n\n  <ask-input\n    (input)=\"onChangePhoneNumber($event)\"\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [extraPadding]=\"true\"\n    [formControl]=\"inputControl\"\n    [isClosed]=\"closed\"\n    [mask]=\"selectedFlag.mask\"\n    [placeholder]=\"'PHONE_PLACEHOLDER' | translate\"\n    [valuePrefix]=\"selectedFlag.code + ' '\"\n    askAutofocus\n    class=\"phone\"\n  />\n\n  <ng-template #loadingPhoneInput>\n    <div class=\"skeleton\">\n      <ask-skeleton [barsHeight]=\"24\" [radius]=\"10\" style=\"height: 24px;\"/>\n    </div>\n  </ng-template>\n\n</div>\n\n<ng-template #overlayContent>\n  <div #menuContainer class=\"menu-container\">\n    <div [style]=\"{padding: '8px'}\">\n      <ask-input\n        [formControl]=\"searchFieldControl\"\n        [placeholder]=\"'FIND_DDI_OR_COUNTRY' | translate\"\n        [autoFocus]=\"true\"\n        class=\"search\"\n      />\n    </div>\n\n    <ng-container *ngIf=\"!filteredOptions.length; else list\">\n      <span class=\"empty\">{{\n        'NO_OPTIONS' | translate\n        }}</span>\n    </ng-container>\n\n    <ng-template #list>\n      <div [askScrollThreshold]=\"50\" askScroll class=\"list\">\n        <ng-container *ngFor=\"let countryItem of filteredOptions\">\n          <div\n            (click)=\"handleOptionSelected(countryItem)\"\n            class=\"option-item\"\n          >\n            <div [style]=\"{backgroundPosition: countryItem.backgroundPosition}\" class=\"country\"></div>\n            <p class=\"text\">{{ display(countryItem) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-ddi.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  inject,\n  Input,\n  Output,\n  Provider,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {TemplatePortal} from \"@angular/cdk/portal\";\nimport {Overlay, OverlayRef} from \"@angular/cdk/overlay\";\nimport {debounceTime, map, Subscription} from \"rxjs\";\nimport {AskDropdownDirective} from \"../../directives\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport {filterSelectedList} from \"../../../shared/helpers/filter.helper\";\nimport CountryFlagService from \"../../../shared/services/country-flag.service\";\nimport {CountryData} from \"../../../shared/providers/flag.provider\";\nimport {NON_DIGIT_REGEX} from \"../../../shared/utils/regex\";\nimport {getCountryFromPhone} from \"../../helpers/phone.helper\";\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => PhoneDdiComponent),\n};\n\n@Component({\n  selector: 'ask-phone-ddi',\n  templateUrl: './phone-ddi.component.html',\n  styleUrls: ['./phone-ddi.component.scss'],\n  providers: [valueAccessor],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PhoneDdiComponent implements AfterViewInit, ControlValueAccessor {\n  @Input() disabled = false;\n  @Input() value = '';\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\n\n  @ViewChild('phoneContainer') phoneContainer: ElementRef | undefined\n\n  @ViewChild('wrapper') wrapper: ElementRef | undefined\n\n  @ViewChild(\"menuContainer\") menuContainer: ElementRef | undefined\n\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  selectedFlag?: CountryData;\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  protected inputControl = new FormControl({value: '', disabled: this.disabled})\n  protected searchFieldControl = new FormControl(\"\")\n  protected filteredOptions: any[] = []\n  protected isValid = true;\n  private _overlayRef: OverlayRef | undefined;\n  private _portal: TemplatePortal<any> | undefined;\n  private _destroy = inject(DestroyRef)\n  private scrollSub?: Subscription;\n\n  constructor(\n    private change: ChangeDetectorRef,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private countryFlagService: CountryFlagService\n  ) {\n  }\n\n  ngAfterViewInit() {\n    this.countryFlagService.list().subscribe(this.addAvailableFlags.bind(this))\n    this.handleInputChange();\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedFlag = item;\n    this.hideOptions();\n    this.inputControl.setValue('');\n    this.searchFieldControl.setValue('');\n    this.onChange('');\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.change.detectChanges();\n  }\n\n  display(option: any) {\n    return this.displayFn(option)\n  }\n\n  @HostListener(\"window:click\", ['$event'])\n  handleClick(event: MouseEvent) {\n    if (\n      !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.menuContainer?.nativeElement.contains(event.target)) {\n      this.hideOptions()\n    }\n  }\n\n  handleFlagClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n    this.change.detectChanges()\n  }\n\n  showOptions() {\n    this.closed = false\n    if (this.phoneContainer) {\n      this._overlayRef = this.getOverlayConfig(this.phoneContainer)\n\n      this._portal = new TemplatePortal(this.overlayContent!, this.viewContainerRef)\n    }\n\n    this._overlayRef?.attach(this._portal);\n  }\n\n  hideOptions() {\n    this.closed = true;\n    this.searchFieldControl.setValue('')\n    this._overlayRef?.detach()\n    this.change.detectChanges()\n    this.scrollSub?.unsubscribe();\n  }\n\n  onChangePhoneNumber(e: any) {\n    const newValue = e.target.value?.replace(NON_DIGIT_REGEX, '');\n\n    if (this.value !== newValue) {\n      this.onChange(newValue)\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.inputControl.setValue(value);\n    const country = getCountryFromPhone(value)\n    if (country) {\n      this.selectedFlag = this.countryItems.find(item => item.countryCode === country)\n    }\n  }\n\n  protected readonly displayFn = (countryFlag: any) => `${countryFlag.countryName} (${countryFlag.code})`;\n\n  protected readonly filterFn = (search: string) =>\n    filterSelectedList(this.countryItems, search, ['code', 'countryName']);\n\n  private addAvailableFlags(data: CountryData[]) {\n    this.countryItems = data;\n    this.filteredOptions = this.countryItems;\n    this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data);\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.change.detectChanges();\n  }\n\n  private handleInputChange() {\n    this.searchFieldControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      map(value => this.filterFn(value || ''))\n    ).subscribe(items => {\n      this.filteredOptions = items\n    })\n  }\n\n  private getOverlayConfig(wrapper: ElementRef) {\n    return this.overlay.create({\n      width: wrapper.nativeElement.offsetWidth,\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy: this.overlay.position()\n        .flexibleConnectedTo(wrapper.nativeElement)\n        .withPositions([{\n          originX: \"start\",\n          originY: \"bottom\",\n          overlayX: \"start\",\n          overlayY: \"top\",\n        }])\n    });\n  }\n}\n","<div #phoneContainer [style]=\"{cursor: disabled ? 'not-allowed' : 'auto'}\" class=\"phone-ddi\">\n\n  <div\n    #wrapper\n    (click)=\"handleFlagClick()\"\n    *ngIf=\"selectedFlag\"\n    [style]=\"{cursor: !disabled ? 'pointer' : 'not-allowed'}\"\n    class=\"flag\"\n    data-testid=\"flag\">\n\n    <div [style]=\"{backgroundPosition: this.selectedFlag?.backgroundPosition}\" class=\"flag-icon\"></div>\n    <div class=\"flag-arrow\"></div>\n  </div>\n\n\n  <ask-input\n    (input)=\"onChangePhoneNumber($event)\"\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [extraPadding]=\"true\"\n    [formControl]=\"inputControl\"\n    [isClosed]=\"closed\"\n    [mask]=\"selectedFlag.mask\"\n    [placeholder]=\"'PHONE_PLACEHOLDER' | translate\"\n    [valuePrefix]=\"selectedFlag.code + ' '\"\n    askAutofocus\n    class=\"phone\"\n  />\n\n  <ng-template #loadingPhoneInput>\n    <div class=\"skeleton\">\n      <ask-skeleton [barsHeight]=\"24\" [radius]=\"10\" style=\"height: 24px;\"/>\n    </div>\n  </ng-template>\n\n</div>\n\n<ng-template #overlayContent>\n  <div #menuContainer class=\"menu-container\">\n    <div [style]=\"{padding: '8px'}\">\n      <ask-input\n        [formControl]=\"searchFieldControl\"\n        [placeholder]=\"'FIND_DDI_OR_COUNTRY' | translate\"\n        [autoFocus]=\"true\"\n        class=\"search\"\n      />\n    </div>\n\n    <ng-container *ngIf=\"!filteredOptions.length; else list\">\n      <span class=\"empty\">{{\n        'NO_OPTIONS' | translate\n        }}</span>\n    </ng-container>\n\n    <ng-template #list>\n      <div [askScrollThreshold]=\"50\" askScroll class=\"list\">\n        <ng-container *ngFor=\"let countryItem of filteredOptions\">\n          <div\n            (click)=\"handleOptionSelected(countryItem)\"\n            class=\"option-item\"\n          >\n            <div [style]=\"{backgroundPosition: countryItem.backgroundPosition}\" class=\"country\"></div>\n            <p class=\"text\">{{ display(countryItem) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
@@ -21,6 +21,7 @@ export class RichtextToolboxDirective {
21
21
  this.inputChange = new EventEmitter();
22
22
  this.inputEnter = new EventEmitter();
23
23
  this.inputEscape = new EventEmitter();
24
+ this.inputFocus = new EventEmitter();
24
25
  this.toolChange = new EventEmitter();
25
26
  }
26
27
  ngOnChanges(sp) {
@@ -86,7 +87,10 @@ export class RichtextToolboxDirective {
86
87
  this.subscription.add(toolbox.richtextWrapper.listenTextChanges$
87
88
  .pipe(filter((v) => v !== this.text))
88
89
  .subscribe((v) => { this.update(v); }));
89
- this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe(() => { this.onTouched(); }));
90
+ this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe((touched) => {
91
+ this.onTouched();
92
+ this.inputFocus.emit(touched);
93
+ }));
90
94
  this.subscription.add(toolbox.richtextWrapper.listenEnter$.subscribe(() => { this.inputEnter.emit(); }));
91
95
  this.subscription.add(toolbox.richtextWrapper.listenEscape$.subscribe(() => { this.inputEscape.emit(); }));
92
96
  this.subscription.add(toolbox.richtextWrapper.state$
@@ -123,7 +127,7 @@ export class RichtextToolboxDirective {
123
127
  }
124
128
  }
125
129
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: RichtextToolboxDirective, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
126
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: RichtextToolboxDirective, selector: "[askRichtextToolbox]", inputs: { rtPlaceholder: "rtPlaceholder", rtTools: "rtTools", rtDisabledTools: "rtDisabledTools", rtType: "rtType", rtToolbarOnly: "rtToolbarOnly", maxlength: "maxlength", rtToolbarClass: "rtToolbarClass", rtEditorClass: "rtEditorClass", rtBreakOnEnter: "rtBreakOnEnter" }, outputs: { inputChange: "inputChange", inputEnter: "inputEnter", inputEscape: "inputEscape", toolChange: "toolChange" }, providers: [
130
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: RichtextToolboxDirective, selector: "[askRichtextToolbox]", inputs: { rtPlaceholder: "rtPlaceholder", rtTools: "rtTools", rtDisabledTools: "rtDisabledTools", rtType: "rtType", rtToolbarOnly: "rtToolbarOnly", maxlength: "maxlength", rtToolbarClass: "rtToolbarClass", rtEditorClass: "rtEditorClass", rtBreakOnEnter: "rtBreakOnEnter" }, outputs: { inputChange: "inputChange", inputEnter: "inputEnter", inputEscape: "inputEscape", inputFocus: "inputFocus", toolChange: "toolChange" }, providers: [
127
131
  {
128
132
  multi: true,
129
133
  provide: NG_VALUE_ACCESSOR,
@@ -167,7 +171,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
167
171
  type: Output
168
172
  }], inputEscape: [{
169
173
  type: Output
174
+ }], inputFocus: [{
175
+ type: Output
170
176
  }], toolChange: [{
171
177
  type: Output
172
178
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-toolbox.directive.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/directives/richtext-toolbox/richtext-toolbox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  forwardRef,\n} from '@angular/core';\nimport {\n  ToolKeys,\n  ToolLayout,\n  ToolsState,\n} from '../../interfaces/richtext-toolbox.interface';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription, distinctUntilChanged, filter } from 'rxjs';\nimport { areObjectsEqual } from '../../helpers/are-objects-equal.helper';\nimport { Toolbox } from '../../classes/toolbox';\nimport { BubbleToolboxProxy } from '../../classes/bubble-toolbox';\nimport { TopbarToolboxProxy } from '../../classes/topbar-toolbox';\n\n@Directive({\n  selector: '[askRichtextToolbox]',\n  providers: [\n    {\n      multi: true,\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RichtextToolboxDirective),\n    },\n  ],\n})\nexport class RichtextToolboxDirective\n  implements OnChanges, ControlValueAccessor\n{\n  private toolbox?: Toolbox;\n\n  private onChange!: (value: string) => void;\n  private onTouched!: () => void;\n  private subscription?: Subscription;\n  private text = '';\n\n  @Input() rtPlaceholder = '';\n  @Input() rtTools: ToolKeys = [];\n  @Input() rtDisabledTools: ToolKeys = [];\n  @Input() rtType: ToolLayout = 'topbar';\n  @Input() rtToolbarOnly = false;\n  @Input() maxlength: number = -1;\n  @Input() rtToolbarClass = '';\n  @Input() rtEditorClass = '';\n  @Input() rtBreakOnEnter = false;\n\n  @Output() inputChange = new EventEmitter<string>();\n  @Output() inputEnter = new EventEmitter();\n  @Output() inputEscape = new EventEmitter();\n  @Output() toolChange = new EventEmitter<ToolsState>();\n\n  constructor(private injector: Injector) {}\n\n  ngOnChanges(sp: SimpleChanges) {\n    if (sp['rtType']) {\n      this.prepareToolbar();\n    }\n\n    if (sp['rtPlaceholder']) {\n      this.toolbox?.richtextWrapper.setPlaceholder(this.rtPlaceholder);\n    }\n    if (sp['rtToolbarOnly']) {\n      this.toolbox?.toggleInputDisplay(!this.rtToolbarOnly)\n    }\n\n    if(sp['maxlength']){\n      this.toolbox?.richtextWrapper.setMaxLength(this.maxlength);\n    }\n\n    if (sp['rtDisabledTools'] || sp['rtTools'] || sp['rtToolbarClass']) {\n      this.toolbox?.setToolInput({\n        availableTools: this.rtTools,\n        disabledTools: this.rtDisabledTools,\n        class: this.rtToolbarClass,\n      })\n    }\n\n    if(sp['rtEditorClass']){\n      this.toolbox?.richtextWrapper.setEditorClass(this.rtEditorClass);\n    }\n\n    if(sp['rtBreakOnEnter']){\n      this.toolbox?.richtextWrapper.setBreakOnEnter(this.rtBreakOnEnter);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyAll();\n  }\n\n  focus() {\n    this.toolbox?.richtextWrapper.focus();\n  }\n\n  //CVA\n\n  writeValue(text: string): void {\n    this.text = text;\n    this.toolbox?.richtextWrapper.setText(text);\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) this.toolbox?.richtextWrapper.disable();\n    else this.toolbox?.richtextWrapper.enable();\n  }\n\n\n  private prepareToolbar(){\n    if (this.toolbox) this.destroyAll();\n\n    this.toolbox = this.generateToolboxLayout(this.rtType);\n    this.prepareListeners(this.toolbox);\n  }\n\n  private prepareListeners(toolbox: Toolbox) {\n    if(this.subscription) this.subscription.unsubscribe();\n    this.subscription = new Subscription();\n    this.subscription.add(toolbox.richtextWrapper.listenTextChanges$\n    .pipe(filter((v)=>v !== this.text))\n    .subscribe((v)=>{this.update(v)}));\n    this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe(()=>{this.onTouched()}));\n    this.subscription.add(toolbox.richtextWrapper.listenEnter$.subscribe(()=>{this.inputEnter.emit()}));\n    this.subscription.add(toolbox.richtextWrapper.listenEscape$.subscribe(()=>{this.inputEscape.emit()}));\n    this.subscription.add(toolbox.richtextWrapper.state$\n      .pipe(distinctUntilChanged((a, b) => areObjectsEqual(a, b)))\n      .subscribe((state)=>{this.toolChange.emit(state)}))\n  \n  }\n\n  private update(value: string){\n    this.inputChange.emit(value);\n    this.onChange(value);\n  }\n\n  private destroyAll() {\n    this.toolbox?.destroyAll();\n    this.subscription?.unsubscribe();\n  }\n\n  private generateToolboxLayout(type: ToolLayout) {\n    const toolbox = this.getToolbox(type);\n    toolbox.richtextWrapper.setPlaceholder(this.rtPlaceholder);\n    toolbox.setToolInput({\n      availableTools: this.rtTools,\n      disabledTools: this.rtDisabledTools,\n      class: this.rtToolbarClass,\n    })\n    toolbox.toggleInputDisplay(!this.rtToolbarOnly)\n    toolbox.richtextWrapper.setMaxLength(this.maxlength);\n    toolbox.richtextWrapper.setEditorClass(this.rtEditorClass);\n    return toolbox;\n  }\n\n  private getToolbox(type: ToolLayout){\n    switch(type){\n      case 'bubble':\n        return new BubbleToolboxProxy.BubbleToolbox(this.injector);\n      case 'topbar':\n        return new TopbarToolboxProxy.TopbarToolbox(this.injector);\n    }\n  }\n}\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-toolbox.directive.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/directives/richtext-toolbox/richtext-toolbox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  forwardRef,\n} from '@angular/core';\nimport {\n  ToolKeys,\n  ToolLayout,\n  ToolsState,\n} from '../../interfaces/richtext-toolbox.interface';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription, distinctUntilChanged, filter } from 'rxjs';\nimport { areObjectsEqual } from '../../helpers/are-objects-equal.helper';\nimport { Toolbox } from '../../classes/toolbox';\nimport { BubbleToolboxProxy } from '../../classes/bubble-toolbox';\nimport { TopbarToolboxProxy } from '../../classes/topbar-toolbox';\n\n@Directive({\n  selector: '[askRichtextToolbox]',\n  providers: [\n    {\n      multi: true,\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RichtextToolboxDirective),\n    },\n  ],\n})\nexport class RichtextToolboxDirective\n  implements OnChanges, ControlValueAccessor\n{\n  private toolbox?: Toolbox;\n\n  private onChange!: (value: string) => void;\n  private onTouched!: () => void;\n  private subscription?: Subscription;\n  private text = '';\n\n  @Input() rtPlaceholder = '';\n  @Input() rtTools: ToolKeys = [];\n  @Input() rtDisabledTools: ToolKeys = [];\n  @Input() rtType: ToolLayout = 'topbar';\n  @Input() rtToolbarOnly = false;\n  @Input() maxlength: number = -1;\n  @Input() rtToolbarClass = '';\n  @Input() rtEditorClass = '';\n  @Input() rtBreakOnEnter = false;\n\n  @Output() inputChange = new EventEmitter<string>();\n  @Output() inputEnter = new EventEmitter();\n  @Output() inputEscape = new EventEmitter();\n  @Output() inputFocus = new EventEmitter();\n  @Output() toolChange = new EventEmitter<ToolsState>();\n\n  constructor(private injector: Injector) {}\n\n  ngOnChanges(sp: SimpleChanges) {\n    if (sp['rtType']) {\n      this.prepareToolbar();\n    }\n\n    if (sp['rtPlaceholder']) {\n      this.toolbox?.richtextWrapper.setPlaceholder(this.rtPlaceholder);\n    }\n    if (sp['rtToolbarOnly']) {\n      this.toolbox?.toggleInputDisplay(!this.rtToolbarOnly)\n    }\n\n    if(sp['maxlength']){\n      this.toolbox?.richtextWrapper.setMaxLength(this.maxlength);\n    }\n\n    if (sp['rtDisabledTools'] || sp['rtTools'] || sp['rtToolbarClass']) {\n      this.toolbox?.setToolInput({\n        availableTools: this.rtTools,\n        disabledTools: this.rtDisabledTools,\n        class: this.rtToolbarClass,\n      })\n    }\n\n    if(sp['rtEditorClass']){\n      this.toolbox?.richtextWrapper.setEditorClass(this.rtEditorClass);\n    }\n\n    if(sp['rtBreakOnEnter']){\n      this.toolbox?.richtextWrapper.setBreakOnEnter(this.rtBreakOnEnter);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyAll();\n  }\n\n  focus() {\n    this.toolbox?.richtextWrapper.focus();\n  }\n\n  //CVA\n\n  writeValue(text: string): void {\n    this.text = text;\n    this.toolbox?.richtextWrapper.setText(text);\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) this.toolbox?.richtextWrapper.disable();\n    else this.toolbox?.richtextWrapper.enable();\n  }\n\n\n  private prepareToolbar(){\n    if (this.toolbox) this.destroyAll();\n\n    this.toolbox = this.generateToolboxLayout(this.rtType);\n    this.prepareListeners(this.toolbox);\n  }\n\n  private prepareListeners(toolbox: Toolbox) {\n    if(this.subscription) this.subscription.unsubscribe();\n    this.subscription = new Subscription();\n    this.subscription.add(toolbox.richtextWrapper.listenTextChanges$\n    .pipe(filter((v)=>v !== this.text))\n    .subscribe((v)=>{this.update(v)}));\n    this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe((touched)=>{\n      this.onTouched()\n      this.inputFocus.emit(touched);\n    }));\n    this.subscription.add(toolbox.richtextWrapper.listenEnter$.subscribe(()=>{this.inputEnter.emit()}));\n    this.subscription.add(toolbox.richtextWrapper.listenEscape$.subscribe(()=>{this.inputEscape.emit()}));\n    this.subscription.add(toolbox.richtextWrapper.state$\n      .pipe(distinctUntilChanged((a, b) => areObjectsEqual(a, b)))\n      .subscribe((state)=>{this.toolChange.emit(state)}))\n  }\n\n  private update(value: string){\n    this.inputChange.emit(value);\n    this.onChange(value);\n  }\n\n  private destroyAll() {\n    this.toolbox?.destroyAll();\n    this.subscription?.unsubscribe();\n  }\n\n  private generateToolboxLayout(type: ToolLayout) {\n    const toolbox = this.getToolbox(type);\n    toolbox.richtextWrapper.setPlaceholder(this.rtPlaceholder);\n    toolbox.setToolInput({\n      availableTools: this.rtTools,\n      disabledTools: this.rtDisabledTools,\n      class: this.rtToolbarClass,\n    })\n    toolbox.toggleInputDisplay(!this.rtToolbarOnly)\n    toolbox.richtextWrapper.setMaxLength(this.maxlength);\n    toolbox.richtextWrapper.setEditorClass(this.rtEditorClass);\n    return toolbox;\n  }\n\n  private getToolbox(type: ToolLayout){\n    switch(type){\n      case 'bubble':\n        return new BubbleToolboxProxy.BubbleToolbox(this.injector);\n      case 'topbar':\n        return new TopbarToolboxProxy.TopbarToolbox(this.injector);\n    }\n  }\n}\n"]}
@@ -0,0 +1,16 @@
1
+ import { parsePhoneNumber } from "libphonenumber-js";
2
+ export function getCountryFromPhone(phone) {
3
+ if (!phone)
4
+ return;
5
+ const onlyNumbers = phone.replace(/[^\d+]/g, '').replace(/\D/g, '');
6
+ try {
7
+ const phoneLocation = parsePhoneNumber(`+${onlyNumbers}`);
8
+ if (phoneLocation && phoneLocation.country)
9
+ return phoneLocation.country;
10
+ }
11
+ catch (e) {
12
+ return 'BR';
13
+ }
14
+ return 'BR';
15
+ }
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUuaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXNrc3VpdGUtY2l0cnVzL3NyYy9saWIvaGVscGVycy9waG9uZS5oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFFbkQsTUFBTSxVQUFVLG1CQUFtQixDQUFDLEtBQWE7SUFDL0MsSUFBSSxDQUFDLEtBQUs7UUFBRSxPQUFPO0lBQ25CLE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFFcEUsSUFBSTtRQUNGLE1BQU0sYUFBYSxHQUFHLGdCQUFnQixDQUFDLElBQUksV0FBVyxFQUFFLENBQUMsQ0FBQztRQUUxRCxJQUFJLGFBQWEsSUFBSSxhQUFhLENBQUMsT0FBTztZQUN4QyxPQUFPLGFBQWEsQ0FBQyxPQUFpQixDQUFDO0tBQzFDO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDVixPQUFPLElBQUksQ0FBQztLQUNiO0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtwYXJzZVBob25lTnVtYmVyfSBmcm9tIFwibGlicGhvbmVudW1iZXItanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldENvdW50cnlGcm9tUGhvbmUocGhvbmU6IHN0cmluZykge1xuICBpZiAoIXBob25lKSByZXR1cm47XG4gIGNvbnN0IG9ubHlOdW1iZXJzID0gcGhvbmUucmVwbGFjZSgvW15cXGQrXS9nLCAnJykucmVwbGFjZSgvXFxEL2csICcnKTtcblxuICB0cnkge1xuICAgIGNvbnN0IHBob25lTG9jYXRpb24gPSBwYXJzZVBob25lTnVtYmVyKGArJHtvbmx5TnVtYmVyc31gKTtcblxuICAgIGlmIChwaG9uZUxvY2F0aW9uICYmIHBob25lTG9jYXRpb24uY291bnRyeSlcbiAgICAgIHJldHVybiBwaG9uZUxvY2F0aW9uLmNvdW50cnkgYXMgc3RyaW5nO1xuICB9IGNhdGNoIChlKSB7XG4gICAgcmV0dXJuICdCUic7XG4gIH1cbiAgcmV0dXJuICdCUic7XG59XG4iXX0=
@@ -8,7 +8,7 @@ import * as i2 from '@angular/forms';
8
8
  import { NG_VALUE_ACCESSOR, FormControl, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
9
9
  import * as i3 from 'ngx-mask';
10
10
  import { NgxMaskDirective, NgxMaskPipe, provideNgxMask } from 'ngx-mask';
11
- import { debounceTime, tap, map, fromEvent, BehaviorSubject, Subject, filter, delay, Subscription, distinctUntilChanged, of } from 'rxjs';
11
+ import { debounceTime, tap, map, fromEvent, filter, BehaviorSubject, Subject, delay, Subscription, distinctUntilChanged, of } from 'rxjs';
12
12
  import { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';
13
13
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
14
14
  import * as i1$2 from '@angular/cdk/overlay';
@@ -21,6 +21,7 @@ import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';
21
21
  import Quill from 'quill';
22
22
  import * as _ from 'lodash';
23
23
  import * as i1$4 from '@angular/common/http';
24
+ import { parsePhoneNumber } from 'libphonenumber-js';
24
25
  import * as i1$5 from '@angular/material/progress-bar';
25
26
  import { MatProgressBarModule } from '@angular/material/progress-bar';
26
27
 
@@ -1844,8 +1845,7 @@ class RichtextWrapper {
1844
1845
  .pipe(map(() => this.quill.root.innerHTML));
1845
1846
  }
1846
1847
  get listenOnTouched$() {
1847
- return fromEvent(this.quill, 'selection-change')
1848
- .pipe(map(() => !this.quill.getSelection(false)));
1848
+ return fromEvent(this.quill, 'selection-change').pipe(filter(() => Boolean(this.quill.getSelection(false))), map(() => null));
1849
1849
  }
1850
1850
  get listenEscape$() {
1851
1851
  return this.esc$.asObservable();
@@ -2525,6 +2525,7 @@ class RichtextToolboxDirective {
2525
2525
  this.inputChange = new EventEmitter();
2526
2526
  this.inputEnter = new EventEmitter();
2527
2527
  this.inputEscape = new EventEmitter();
2528
+ this.inputFocus = new EventEmitter();
2528
2529
  this.toolChange = new EventEmitter();
2529
2530
  }
2530
2531
  ngOnChanges(sp) {
@@ -2590,7 +2591,10 @@ class RichtextToolboxDirective {
2590
2591
  this.subscription.add(toolbox.richtextWrapper.listenTextChanges$
2591
2592
  .pipe(filter((v) => v !== this.text))
2592
2593
  .subscribe((v) => { this.update(v); }));
2593
- this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe(() => { this.onTouched(); }));
2594
+ this.subscription.add(toolbox.richtextWrapper.listenOnTouched$.subscribe((touched) => {
2595
+ this.onTouched();
2596
+ this.inputFocus.emit(touched);
2597
+ }));
2594
2598
  this.subscription.add(toolbox.richtextWrapper.listenEnter$.subscribe(() => { this.inputEnter.emit(); }));
2595
2599
  this.subscription.add(toolbox.richtextWrapper.listenEscape$.subscribe(() => { this.inputEscape.emit(); }));
2596
2600
  this.subscription.add(toolbox.richtextWrapper.state$
@@ -2627,7 +2631,7 @@ class RichtextToolboxDirective {
2627
2631
  }
2628
2632
  }
2629
2633
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: RichtextToolboxDirective, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
2630
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: RichtextToolboxDirective, selector: "[askRichtextToolbox]", inputs: { rtPlaceholder: "rtPlaceholder", rtTools: "rtTools", rtDisabledTools: "rtDisabledTools", rtType: "rtType", rtToolbarOnly: "rtToolbarOnly", maxlength: "maxlength", rtToolbarClass: "rtToolbarClass", rtEditorClass: "rtEditorClass", rtBreakOnEnter: "rtBreakOnEnter" }, outputs: { inputChange: "inputChange", inputEnter: "inputEnter", inputEscape: "inputEscape", toolChange: "toolChange" }, providers: [
2634
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: RichtextToolboxDirective, selector: "[askRichtextToolbox]", inputs: { rtPlaceholder: "rtPlaceholder", rtTools: "rtTools", rtDisabledTools: "rtDisabledTools", rtType: "rtType", rtToolbarOnly: "rtToolbarOnly", maxlength: "maxlength", rtToolbarClass: "rtToolbarClass", rtEditorClass: "rtEditorClass", rtBreakOnEnter: "rtBreakOnEnter" }, outputs: { inputChange: "inputChange", inputEnter: "inputEnter", inputEscape: "inputEscape", inputFocus: "inputFocus", toolChange: "toolChange" }, providers: [
2631
2635
  {
2632
2636
  multi: true,
2633
2637
  provide: NG_VALUE_ACCESSOR,
@@ -2671,6 +2675,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
2671
2675
  type: Output
2672
2676
  }], inputEscape: [{
2673
2677
  type: Output
2678
+ }], inputFocus: [{
2679
+ type: Output
2674
2680
  }], toolChange: [{
2675
2681
  type: Output
2676
2682
  }] } });
@@ -3136,6 +3142,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
3136
3142
  const DIGIT_REGEX = /\d/g;
3137
3143
  const NON_DIGIT_REGEX = /\D+/g;
3138
3144
 
3145
+ function getCountryFromPhone(phone) {
3146
+ if (!phone)
3147
+ return;
3148
+ const onlyNumbers = phone.replace(/[^\d+]/g, '').replace(/\D/g, '');
3149
+ try {
3150
+ const phoneLocation = parsePhoneNumber(`+${onlyNumbers}`);
3151
+ if (phoneLocation && phoneLocation.country)
3152
+ return phoneLocation.country;
3153
+ }
3154
+ catch (e) {
3155
+ return 'BR';
3156
+ }
3157
+ return 'BR';
3158
+ }
3159
+
3139
3160
  const valueAccessor = {
3140
3161
  provide: NG_VALUE_ACCESSOR,
3141
3162
  multi: true,
@@ -3223,7 +3244,10 @@ class PhoneDdiComponent {
3223
3244
  writeValue(value) {
3224
3245
  this.value = value;
3225
3246
  this.inputControl.setValue(value);
3226
- this.valueChange.emit(this.value);
3247
+ const country = getCountryFromPhone(value);
3248
+ if (country) {
3249
+ this.selectedFlag = this.countryItems.find(item => item.countryCode === country);
3250
+ }
3227
3251
  }
3228
3252
  addAvailableFlags(data) {
3229
3253
  this.countryItems = data;