@libs-ui/components-inputs-mention 0.2.304 → 0.2.306-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.
@@ -1,4 +1,4 @@
1
- import { IMentionConfig } from "../interfaces/mention.interface";
1
+ import { IMentionConfig } from '../interfaces/mention.interface';
2
2
  export declare const PATTERN_INSERT = "\uFEFF";
3
3
  export declare const buildTemplate: (value: string, id: string, feId: string) => string;
4
4
  export declare const DEFAULT_CONFIG: IMentionConfig;
@@ -1,5 +1,5 @@
1
1
  /* From: https://github.com/component/textarea-caret-position */
2
- import { get, isNil, set } from "@libs-ui/utils";
2
+ import { get, isNil, set } from '@libs-ui/utils';
3
3
  // We'll copy the properties below into the mirror div.
4
4
  // Note that some browsers, such as Firefox, do not concatenate properties
5
5
  // into their shorthand (e.g. padding-top, padding-bottom etc. -> padding),
@@ -36,10 +36,10 @@ const properties = [
36
36
  'letterSpacing',
37
37
  'wordSpacing',
38
38
  'tabSize',
39
- 'MozTabSize'
39
+ 'MozTabSize',
40
40
  ];
41
- const isBrowser = (typeof window !== 'undefined');
42
- const isFirefox = (isBrowser && get(window, 'mozInnerScreenX') !== null);
41
+ const isBrowser = typeof window !== 'undefined';
42
+ const isFirefox = isBrowser && get(window, 'mozInnerScreenX') !== null;
43
43
  export const getCaretCoordinates = (element, position) => {
44
44
  if (!isBrowser) {
45
45
  throw new Error('textarea-caret-position#getCaretCoordinates should only be called in a browser');
@@ -59,10 +59,10 @@ export const getCaretCoordinates = (element, position) => {
59
59
  // Position off-screen
60
60
  style.position = 'absolute'; // required to return coordinates properly
61
61
  // Transfer the element's properties to the div
62
- properties.forEach(prop => {
62
+ properties.forEach((prop) => {
63
63
  if (isInput && prop === 'lineHeight') {
64
64
  // Special case for <input>s because text is rendered centered and line height may be != height
65
- if (computed.boxSizing !== "border-box") {
65
+ if (computed.boxSizing !== 'border-box') {
66
66
  style.lineHeight = computed.height;
67
67
  return;
68
68
  }
@@ -70,7 +70,7 @@ export const getCaretCoordinates = (element, position) => {
70
70
  const outerHeight = parseInt(computed.paddingTop) + parseInt(computed.paddingBottom) + parseInt(computed.borderTopWidth) + parseInt(computed.borderBottomWidth);
71
71
  const targetHeight = outerHeight + parseInt(computed.lineHeight);
72
72
  if (height > targetHeight) {
73
- style.lineHeight = height - outerHeight + "px";
73
+ style.lineHeight = height - outerHeight + 'px';
74
74
  return;
75
75
  }
76
76
  if (height === targetHeight) {
@@ -107,9 +107,9 @@ export const getCaretCoordinates = (element, position) => {
107
107
  const coordinates = {
108
108
  top: span.offsetTop + parseInt(computed['borderTopWidth']),
109
109
  left: span.offsetLeft + parseInt(computed['borderLeftWidth']),
110
- height: parseInt(computed['lineHeight'])
110
+ height: parseInt(computed['lineHeight']),
111
111
  };
112
112
  document.body.removeChild(div);
113
113
  return coordinates;
114
114
  };
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"caret-coords.define.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/mention/src/defines/caret-coords.define.ts"],"names":[],"mappings":"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","sourcesContent":["/* From: https://github.com/component/textarea-caret-position */\n\nimport { get, isNil, set } from \"@libs-ui/utils\";\n\n// We'll copy the properties below into the mirror div.\n// Note that some browsers, such as Firefox, do not concatenate properties\n// into their shorthand (e.g. padding-top, padding-bottom etc. -> padding),\n// so we have to list every single property explicitly.\nconst properties = [\n  'direction', // RTL support\n  'boxSizing',\n  'width', // on Chrome and IE, exclude the scrollbar, so the mirror div wraps exactly as the textarea does\n  'height',\n  'overflowX',\n  'overflowY', // copy the scrollbar for IE\n\n  'borderTopWidth',\n  'borderRightWidth',\n  'borderBottomWidth',\n  'borderLeftWidth',\n  'borderStyle',\n\n  'paddingTop',\n  'paddingRight',\n  'paddingBottom',\n  'paddingLeft',\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/font\n  'fontStyle',\n  'fontVariant',\n  'fontWeight',\n  'fontStretch',\n  'fontSize',\n  'fontSizeAdjust',\n  'lineHeight',\n  'fontFamily',\n\n  'textAlign',\n  'textTransform',\n  'textIndent',\n  'textDecoration', // might not make a difference, but better be safe\n\n  'letterSpacing',\n  'wordSpacing',\n\n  'tabSize',\n  'MozTabSize'\n\n];\n\nconst isBrowser = (typeof window !== 'undefined');\nconst isFirefox = (isBrowser && get(window, 'mozInnerScreenX') !== null);\n\nexport const getCaretCoordinates = (element: Element, position: number | null) => {\n  if (!isBrowser) {\n    throw new Error('textarea-caret-position#getCaretCoordinates should only be called in a browser');\n  }\n\n  // The mirror div will replicate the textarea's style\n  const div: HTMLDivElement = document.createElement('div');\n\n  div.id = 'input-textarea-caret-position-mirror-div';\n  document.body.appendChild(div);\n\n  const style = div.style;\n  const computed = window.getComputedStyle ? window.getComputedStyle(element) : get(element, 'currentStyle'); // currentStyle for IE < 9\n  const isInput = element.nodeName === 'INPUT';\n\n  // Default textarea styles\n  style.whiteSpace = 'pre-wrap';\n  if (!isInput) { style.wordBreak = 'break-word' } // only for textarea-s\n\n  // Position off-screen\n  style.position = 'absolute'; // required to return coordinates properly\n\n  // Transfer the element's properties to the div\n  properties.forEach(prop => {\n    if (isInput && prop === 'lineHeight') {\n      // Special case for <input>s because text is rendered centered and line height may be != height\n      if (computed.boxSizing !== \"border-box\") {\n        style.lineHeight = computed.height;\n\n        return;\n      }\n      const height = parseInt(computed.height);\n      const outerHeight = parseInt(computed.paddingTop) + parseInt(computed.paddingBottom) + parseInt(computed.borderTopWidth) + parseInt(computed.borderBottomWidth);\n      const targetHeight = outerHeight + parseInt(computed.lineHeight);\n\n      if (height > targetHeight) {\n        style.lineHeight = height - outerHeight + \"px\";\n\n        return;\n      }\n      if (height === targetHeight) {\n        style.lineHeight = computed.lineHeight;\n\n        return;\n      }\n      style.lineHeight = '0';\n\n      return;\n    }\n    set(style, prop, computed[prop]);\n  });\n\n  if (!isFirefox) {\n    style.overflow = 'hidden';\n    // Firefox lies about the overflow property for textareas: https://bugzilla.mozilla.org/show_bug.cgi?id=984275\n  }\n  const value = get(element, 'value');\n  if (isFirefox && element.scrollHeight > parseInt(computed.height)) { style.overflowY = 'scroll' }\n  div.textContent = value.substring(0, position);\n  // The second special handling for input type=\"text\" vs textarea:\n  // spaces need to be replaced with non-breaking spaces - http://stackoverflow.com/a/13402035/1269037\n  if (isInput && !isNil(div.textContent)) {\n    div.textContent = div.textContent.replace(/\\s/g, '\\u00a0');\n  }\n  const span = document.createElement('span');\n\n  // Wrapping must be replicated *exactly*, including when a long word gets\n  // onto the next line, with whitespace at the end of the line before (#7).\n  // The  *only* reliable way to do that is to copy the *entire* rest of the\n  // textarea's content into the <span> created at the caret position.\n  // For inputs, just '.' would be enough, but no need to bother.\n  span.textContent = value.substring(position) || '.'; // || because a completely empty faux span doesn't render at all\n  div.appendChild(span);\n\n  const coordinates = {\n    top: span.offsetTop + parseInt(computed['borderTopWidth']),\n    left: span.offsetLeft + parseInt(computed['borderLeftWidth']),\n    height: parseInt(computed['lineHeight'])\n  };\n\n  document.body.removeChild(div);\n\n  return coordinates;\n};\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"caret-coords.define.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/mention/src/defines/caret-coords.define.ts"],"names":[],"mappings":"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","sourcesContent":["/* From: https://github.com/component/textarea-caret-position */\n\nimport { PathsToStringProps } from '@libs-ui/interfaces-types';\nimport { get, isNil, set } from '@libs-ui/utils';\n\n// We'll copy the properties below into the mirror div.\n// Note that some browsers, such as Firefox, do not concatenate properties\n// into their shorthand (e.g. padding-top, padding-bottom etc. -> padding),\n// so we have to list every single property explicitly.\nconst properties = [\n  'direction', // RTL support\n  'boxSizing',\n  'width', // on Chrome and IE, exclude the scrollbar, so the mirror div wraps exactly as the textarea does\n  'height',\n  'overflowX',\n  'overflowY', // copy the scrollbar for IE\n\n  'borderTopWidth',\n  'borderRightWidth',\n  'borderBottomWidth',\n  'borderLeftWidth',\n  'borderStyle',\n\n  'paddingTop',\n  'paddingRight',\n  'paddingBottom',\n  'paddingLeft',\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/font\n  'fontStyle',\n  'fontVariant',\n  'fontWeight',\n  'fontStretch',\n  'fontSize',\n  'fontSizeAdjust',\n  'lineHeight',\n  'fontFamily',\n\n  'textAlign',\n  'textTransform',\n  'textIndent',\n  'textDecoration', // might not make a difference, but better be safe\n\n  'letterSpacing',\n  'wordSpacing',\n\n  'tabSize',\n  'MozTabSize',\n];\n\nconst isBrowser = typeof window !== 'undefined';\nconst isFirefox = isBrowser && get(window, 'mozInnerScreenX') !== null;\n\nexport const getCaretCoordinates = (element: Element, position: number | null) => {\n  if (!isBrowser) {\n    throw new Error('textarea-caret-position#getCaretCoordinates should only be called in a browser');\n  }\n\n  // The mirror div will replicate the textarea's style\n  const div: HTMLDivElement = document.createElement('div');\n\n  div.id = 'input-textarea-caret-position-mirror-div';\n  document.body.appendChild(div);\n\n  const style = div.style;\n  const computed = window.getComputedStyle ? window.getComputedStyle(element) : get(element, 'currentStyle'); // currentStyle for IE < 9\n  const isInput = element.nodeName === 'INPUT';\n\n  // Default textarea styles\n  style.whiteSpace = 'pre-wrap';\n  if (!isInput) {\n    style.wordBreak = 'break-word';\n  } // only for textarea-s\n\n  // Position off-screen\n  style.position = 'absolute'; // required to return coordinates properly\n\n  // Transfer the element's properties to the div\n  properties.forEach((prop) => {\n    if (isInput && prop === 'lineHeight') {\n      // Special case for <input>s because text is rendered centered and line height may be != height\n      if (computed.boxSizing !== 'border-box') {\n        style.lineHeight = computed.height;\n\n        return;\n      }\n      const height = parseInt(computed.height);\n      const outerHeight = parseInt(computed.paddingTop) + parseInt(computed.paddingBottom) + parseInt(computed.borderTopWidth) + parseInt(computed.borderBottomWidth);\n      const targetHeight = outerHeight + parseInt(computed.lineHeight);\n\n      if (height > targetHeight) {\n        style.lineHeight = height - outerHeight + 'px';\n\n        return;\n      }\n      if (height === targetHeight) {\n        style.lineHeight = computed.lineHeight;\n\n        return;\n      }\n      style.lineHeight = '0';\n\n      return;\n    }\n    set(style, prop as PathsToStringProps<CSSStyleDeclaration>, computed[prop]);\n  });\n\n  if (!isFirefox) {\n    style.overflow = 'hidden';\n    // Firefox lies about the overflow property for textareas: https://bugzilla.mozilla.org/show_bug.cgi?id=984275\n  }\n  const value = get(element, 'value');\n  if (isFirefox && element.scrollHeight > parseInt(computed.height)) {\n    style.overflowY = 'scroll';\n  }\n  div.textContent = value.substring(0, position);\n  // The second special handling for input type=\"text\" vs textarea:\n  // spaces need to be replaced with non-breaking spaces - http://stackoverflow.com/a/13402035/1269037\n  if (isInput && !isNil(div.textContent)) {\n    div.textContent = div.textContent.replace(/\\s/g, '\\u00a0');\n  }\n  const span = document.createElement('span');\n\n  // Wrapping must be replicated *exactly*, including when a long word gets\n  // onto the next line, with whitespace at the end of the line before (#7).\n  // The  *only* reliable way to do that is to copy the *entire* rest of the\n  // textarea's content into the <span> created at the caret position.\n  // For inputs, just '.' would be enough, but no need to bother.\n  span.textContent = value.substring(position) || '.'; // || because a completely empty faux span doesn't render at all\n  div.appendChild(span);\n\n  const coordinates = {\n    top: span.offsetTop + parseInt(computed['borderTopWidth']),\n    left: span.offsetLeft + parseInt(computed['borderLeftWidth']),\n    height: parseInt(computed['lineHeight']),\n  };\n\n  document.body.removeChild(div);\n\n  return coordinates;\n};\n"]}
@@ -1,4 +1,5 @@
1
- import { deleteUnicode, get } from "@libs-ui/utils";
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { deleteUnicode, get } from '@libs-ui/utils';
2
3
  export const PATTERN_INSERT = '\ufeff';
3
4
  export const buildTemplate = (value, id, feId) => {
4
5
  return `<span class="libs-ui-components-mention-item" style="font-weight: 600;-moz-osx-font-smoothing: grayscale;-webkit-font-smoothing: antialiased; color: #7239EA" contenteditable="false" id="${id}" feId="${feId}" value="${value}">${value}</span>&nbsp;`;
@@ -15,11 +16,11 @@ export const DEFAULT_CONFIG = {
15
16
  mentionSelect: (item) => `@${get(item, 'email')}`,
16
17
  mentionFilter: (search, items) => {
17
18
  const searchString = deleteUnicode(search.toLowerCase());
18
- return items?.filter(item => {
19
+ return items?.filter((item) => {
19
20
  const name = deleteUnicode(get(item, 'name').toLowerCase());
20
21
  const userName = deleteUnicode(get(item, 'username').toLowerCase());
21
22
  return name.includes(searchString) || userName.includes(searchString);
22
23
  });
23
- }
24
+ },
24
25
  };
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuZGVmaW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9tZW50aW9uL3NyYy9kZWZpbmVzL3RlbXBsYXRlLmRlZmluZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXBELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxRQUFRLENBQUM7QUFFdkMsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBYSxFQUFFLEVBQVUsRUFBRSxJQUFZLEVBQVUsRUFBRTtJQUMvRSxPQUFPLDZMQUE2TCxFQUFFLFdBQVcsSUFBSSxZQUFZLEtBQUssS0FBSyxLQUFLLGVBQWUsQ0FBQztBQUNsUSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQW1CO0lBQzVDLEtBQUssRUFBRSxFQUFFO0lBQ1QsV0FBVyxFQUFFLEdBQUc7SUFDaEIsUUFBUSxFQUFFLE9BQU87SUFDakIsVUFBVSxFQUFFLElBQUk7SUFDaEIsYUFBYSxFQUFFLEtBQUs7SUFDcEIscUJBQXFCLEVBQUUsQ0FBQztJQUN4QixnQkFBZ0IsRUFBRSxPQUFPO0lBQ3pCLG9CQUFvQixFQUFFLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDO0lBQ25FLGFBQWEsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxHQUFHLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxFQUFFO0lBQ2pELGFBQWEsRUFBRSxDQUFDLE1BQWMsRUFBRSxLQUFzQixFQUFFLEVBQUU7UUFDeEQsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBRXpELE9BQU8sS0FBSyxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUMxQixNQUFNLElBQUksR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1lBQzVELE1BQU0sUUFBUSxHQUFHLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7WUFFcEUsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlbGV0ZVVuaWNvZGUsIGdldCB9IGZyb20gXCJAbGlicy11aS91dGlsc1wiO1xyXG5pbXBvcnQgeyBJTWVudGlvbkNvbmZpZyB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL21lbnRpb24uaW50ZXJmYWNlXCI7XHJcbmV4cG9ydCBjb25zdCBQQVRURVJOX0lOU0VSVCA9ICdcXHVmZWZmJztcclxuXHJcbmV4cG9ydCBjb25zdCBidWlsZFRlbXBsYXRlID0gKHZhbHVlOiBzdHJpbmcsIGlkOiBzdHJpbmcsIGZlSWQ6IHN0cmluZyk6IHN0cmluZyA9PiB7XHJcbiAgcmV0dXJuIGA8c3BhbiBjbGFzcz1cImxpYnMtdWktY29tcG9uZW50cy1tZW50aW9uLWl0ZW1cIiBzdHlsZT1cImZvbnQtd2VpZ2h0OiA2MDA7LW1vei1vc3gtZm9udC1zbW9vdGhpbmc6IGdyYXlzY2FsZTstd2Via2l0LWZvbnQtc21vb3RoaW5nOiBhbnRpYWxpYXNlZDsgY29sb3I6ICM3MjM5RUFcIiBjb250ZW50ZWRpdGFibGU9XCJmYWxzZVwiIGlkPVwiJHtpZH1cIiBmZUlkPVwiJHtmZUlkfVwiIHZhbHVlPVwiJHt2YWx1ZX1cIj4ke3ZhbHVlfTwvc3Bhbj4mbmJzcDtgO1xyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfQ09ORklHOiBJTWVudGlvbkNvbmZpZyA9IHtcclxuICBpdGVtczogW10sXHJcbiAgdHJpZ2dlckNoYXI6ICdAJyxcclxuICBsYWJlbEtleTogJ2VtYWlsJyxcclxuICBhbGxvd1NwYWNlOiB0cnVlLFxyXG4gIHJldHVyblRyaWdnZXI6IGZhbHNlLFxyXG4gIGxpbWl0U3BhY2VTZWFyY2hRdWVyeTogMyxcclxuICBtZW50aW9uRXZlbnROYW1lOiAnY2xpY2snLFxyXG4gIG1lbnRpb25BY3Rpb25CeUV2ZW50OiAoaXRlbSwgdHJpZ2dlcikgPT4gY29uc29sZS5sb2coaXRlbSwgdHJpZ2dlciksXHJcbiAgbWVudGlvblNlbGVjdDogKGl0ZW0pID0+IGBAJHtnZXQoaXRlbSwgJ2VtYWlsJyl9YCxcclxuICBtZW50aW9uRmlsdGVyOiAoc2VhcmNoOiBzdHJpbmcsIGl0ZW1zPzogQXJyYXk8dW5rbm93bj4pID0+IHtcclxuICAgIGNvbnN0IHNlYXJjaFN0cmluZyA9IGRlbGV0ZVVuaWNvZGUoc2VhcmNoLnRvTG93ZXJDYXNlKCkpO1xyXG5cclxuICAgIHJldHVybiBpdGVtcz8uZmlsdGVyKGl0ZW0gPT4ge1xyXG4gICAgICBjb25zdCBuYW1lID0gZGVsZXRlVW5pY29kZShnZXQoaXRlbSwgJ25hbWUnKS50b0xvd2VyQ2FzZSgpKTtcclxuICAgICAgY29uc3QgdXNlck5hbWUgPSBkZWxldGVVbmljb2RlKGdldChpdGVtLCAndXNlcm5hbWUnKS50b0xvd2VyQ2FzZSgpKTtcclxuXHJcbiAgICAgIHJldHVybiBuYW1lLmluY2x1ZGVzKHNlYXJjaFN0cmluZykgfHwgdXNlck5hbWUuaW5jbHVkZXMoc2VhcmNoU3RyaW5nKTtcclxuICAgIH0pO1xyXG4gIH1cclxufTsiXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuZGVmaW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9tZW50aW9uL3NyYy9kZWZpbmVzL3RlbXBsYXRlLmRlZmluZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVwRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsUUFBUSxDQUFDO0FBRXZDLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxDQUFDLEtBQWEsRUFBRSxFQUFVLEVBQUUsSUFBWSxFQUFVLEVBQUU7SUFDL0UsT0FBTyw2TEFBNkwsRUFBRSxXQUFXLElBQUksWUFBWSxLQUFLLEtBQUssS0FBSyxlQUFlLENBQUM7QUFDbFEsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFtQjtJQUM1QyxLQUFLLEVBQUUsRUFBRTtJQUNULFdBQVcsRUFBRSxHQUFHO0lBQ2hCLFFBQVEsRUFBRSxPQUFPO0lBQ2pCLFVBQVUsRUFBRSxJQUFJO0lBQ2hCLGFBQWEsRUFBRSxLQUFLO0lBQ3BCLHFCQUFxQixFQUFFLENBQUM7SUFDeEIsZ0JBQWdCLEVBQUUsT0FBTztJQUN6QixvQkFBb0IsRUFBRSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQztJQUNuRSxhQUFhLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsRUFBRTtJQUNqRCxhQUFhLEVBQUUsQ0FBQyxNQUFjLEVBQUUsS0FBc0IsRUFBRSxFQUFFO1FBQ3hELE1BQU0sWUFBWSxHQUFHLGFBQWEsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUV6RCxPQUFPLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUM1QixNQUFNLElBQUksR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFNLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1lBQ2pFLE1BQU0sUUFBUSxHQUFHLGFBQWEsQ0FBQyxHQUFHLENBQU0sSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7WUFFekUsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDeEUsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cclxuaW1wb3J0IHsgZGVsZXRlVW5pY29kZSwgZ2V0IH0gZnJvbSAnQGxpYnMtdWkvdXRpbHMnO1xyXG5pbXBvcnQgeyBJTWVudGlvbkNvbmZpZyB9IGZyb20gJy4uL2ludGVyZmFjZXMvbWVudGlvbi5pbnRlcmZhY2UnO1xyXG5leHBvcnQgY29uc3QgUEFUVEVSTl9JTlNFUlQgPSAnXFx1ZmVmZic7XHJcblxyXG5leHBvcnQgY29uc3QgYnVpbGRUZW1wbGF0ZSA9ICh2YWx1ZTogc3RyaW5nLCBpZDogc3RyaW5nLCBmZUlkOiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xyXG4gIHJldHVybiBgPHNwYW4gY2xhc3M9XCJsaWJzLXVpLWNvbXBvbmVudHMtbWVudGlvbi1pdGVtXCIgc3R5bGU9XCJmb250LXdlaWdodDogNjAwOy1tb3otb3N4LWZvbnQtc21vb3RoaW5nOiBncmF5c2NhbGU7LXdlYmtpdC1mb250LXNtb290aGluZzogYW50aWFsaWFzZWQ7IGNvbG9yOiAjNzIzOUVBXCIgY29udGVudGVkaXRhYmxlPVwiZmFsc2VcIiBpZD1cIiR7aWR9XCIgZmVJZD1cIiR7ZmVJZH1cIiB2YWx1ZT1cIiR7dmFsdWV9XCI+JHt2YWx1ZX08L3NwYW4+Jm5ic3A7YDtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0NPTkZJRzogSU1lbnRpb25Db25maWcgPSB7XHJcbiAgaXRlbXM6IFtdLFxyXG4gIHRyaWdnZXJDaGFyOiAnQCcsXHJcbiAgbGFiZWxLZXk6ICdlbWFpbCcsXHJcbiAgYWxsb3dTcGFjZTogdHJ1ZSxcclxuICByZXR1cm5UcmlnZ2VyOiBmYWxzZSxcclxuICBsaW1pdFNwYWNlU2VhcmNoUXVlcnk6IDMsXHJcbiAgbWVudGlvbkV2ZW50TmFtZTogJ2NsaWNrJyxcclxuICBtZW50aW9uQWN0aW9uQnlFdmVudDogKGl0ZW0sIHRyaWdnZXIpID0+IGNvbnNvbGUubG9nKGl0ZW0sIHRyaWdnZXIpLFxyXG4gIG1lbnRpb25TZWxlY3Q6IChpdGVtKSA9PiBgQCR7Z2V0KGl0ZW0sICdlbWFpbCcpfWAsXHJcbiAgbWVudGlvbkZpbHRlcjogKHNlYXJjaDogc3RyaW5nLCBpdGVtcz86IEFycmF5PHVua25vd24+KSA9PiB7XHJcbiAgICBjb25zdCBzZWFyY2hTdHJpbmcgPSBkZWxldGVVbmljb2RlKHNlYXJjaC50b0xvd2VyQ2FzZSgpKTtcclxuXHJcbiAgICByZXR1cm4gaXRlbXM/LmZpbHRlcigoaXRlbSkgPT4ge1xyXG4gICAgICBjb25zdCBuYW1lID0gZGVsZXRlVW5pY29kZShnZXQ8YW55PihpdGVtLCAnbmFtZScpLnRvTG93ZXJDYXNlKCkpO1xyXG4gICAgICBjb25zdCB1c2VyTmFtZSA9IGRlbGV0ZVVuaWNvZGUoZ2V0PGFueT4oaXRlbSwgJ3VzZXJuYW1lJykudG9Mb3dlckNhc2UoKSk7XHJcblxyXG4gICAgICByZXR1cm4gbmFtZS5pbmNsdWRlcyhzZWFyY2hTdHJpbmcpIHx8IHVzZXJOYW1lLmluY2x1ZGVzKHNlYXJjaFN0cmluZyk7XHJcbiAgICB9KTtcclxuICB9LFxyXG59O1xyXG4iXX0=
@@ -1,11 +1,11 @@
1
- import { ChangeDetectionStrategy, Component, model, signal, viewChild, viewChildren } from "@angular/core";
2
- import { LibsUiComponentsAvatarComponent } from "@libs-ui/components-avatar";
3
- import { LibsUiComponentsPopoverComponent } from "@libs-ui/components-popover";
4
- import { set } from "@libs-ui/utils";
5
- import { fromEvent, Subject, takeUntil } from "rxjs";
6
- import { getCaretCoordinates } from "../defines/caret-coords.define";
7
- import { KEY_ENTER } from "../defines/keyboard.define";
8
- import { getContentEditableCaretCoords, isInputOrTextAreaElement } from "../defines/utils.define";
1
+ import { ChangeDetectionStrategy, Component, model, signal, viewChild, viewChildren } from '@angular/core';
2
+ import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
3
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
4
+ import { set } from '@libs-ui/utils';
5
+ import { fromEvent, Subject, takeUntil } from 'rxjs';
6
+ import { getCaretCoordinates } from '../defines/caret-coords.define';
7
+ import { KEY_ENTER } from '../defines/keyboard.define';
8
+ import { getContentEditableCaretCoords, isInputOrTextAreaElement } from '../defines/utils.define';
9
9
  import * as i0 from "@angular/core";
10
10
  export class LibsUiComponentsInputsMentionListComponent {
11
11
  // #region PROPERTY
@@ -38,7 +38,9 @@ export class LibsUiComponentsInputsMentionListComponent {
38
38
  }
39
39
  /* FUNCTIONS */
40
40
  initEvent(element, eventName) {
41
- fromEvent(element, eventName).pipe(takeUntil(this.onDestroy)).subscribe((event) => {
41
+ fromEvent(element, eventName)
42
+ .pipe(takeUntil(this.onDestroy))
43
+ .subscribe((event) => {
42
44
  if (eventName === 'resize' || !this.elementEl()?.nativeElement.contains(event.target)) {
43
45
  this.handlerListenClose(event);
44
46
  }
@@ -55,10 +57,10 @@ export class LibsUiComponentsInputsMentionListComponent {
55
57
  if (isInputOrTextAreaElement(nativeParentElement)) {
56
58
  // parent elements need to have postition:relative for this to work correctly?
57
59
  this.coords.set(getCaretCoordinates(nativeParentElement, nativeParentElement.selectionStart));
58
- this.coords.update(item => ({
60
+ this.coords.update((item) => ({
59
61
  ...item,
60
62
  top: nativeParentElement.offsetTop + item.top - nativeParentElement.scrollTop,
61
- left: nativeParentElement.offsetLeft + item.left - nativeParentElement.scrollLeft + nativeParentElement.getBoundingClientRect().left
63
+ left: nativeParentElement.offsetLeft + item.left - nativeParentElement.scrollLeft + nativeParentElement.getBoundingClientRect().left,
62
64
  }));
63
65
  // getCretCoordinates() for text/input elements needs an additional offset to position the list correctly
64
66
  this.offset.set(this.getBlockCursorDimensions(nativeParentElement).height);
@@ -71,15 +73,15 @@ export class LibsUiComponentsInputsMentionListComponent {
71
73
  const caretRelativeToView = getContentEditableCaretCoords(context);
72
74
  const doc = document.documentElement;
73
75
  const scrollLeft = (window.scrollX || doc.scrollLeft) - (doc.clientLeft || 0);
74
- this.coords.update(item => ({
76
+ this.coords.update((item) => ({
75
77
  ...item,
76
78
  left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),
77
- bottom: window.parent.innerHeight - caretRelativeToView.top + 18
79
+ bottom: window.parent.innerHeight - caretRelativeToView.top + 18,
78
80
  }));
79
81
  if (caretRelativeToView.bottom && caretRelativeToView.bottom !== -1) {
80
- this.coords.update(item => ({
82
+ this.coords.update((item) => ({
81
83
  ...item,
82
- bottom: caretRelativeToView.bottom
84
+ bottom: caretRelativeToView.bottom,
83
85
  }));
84
86
  }
85
87
  this.positionElement();
@@ -90,11 +92,11 @@ export class LibsUiComponentsInputsMentionListComponent {
90
92
  const scrollTop = (window.scrollX || doc.scrollTop) - (doc.clientTop || 0);
91
93
  // bounding rectangles are relative to view, offsets are relative to container?
92
94
  const caretRelativeToView = getContentEditableCaretCoords({ iframe, parent: null });
93
- this.coords.update(item => ({
95
+ this.coords.update((item) => ({
94
96
  ...item,
95
97
  top: caretRelativeToView.top - scrollTop + 10,
96
98
  left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),
97
- bottom: caretRelativeToView.bottom
99
+ bottom: caretRelativeToView.bottom,
98
100
  }));
99
101
  this.positionElement();
100
102
  }
@@ -118,7 +120,7 @@ export class LibsUiComponentsInputsMentionListComponent {
118
120
  positionElement(left = this.coords().left, top = this.coords().top, dropUp = this.dropUp(), bottom = this.coords().bottom || 0) {
119
121
  const el = this.elementEl()?.nativeElement;
120
122
  top += dropUp ? 0 : this.offset(); // top of list is next line
121
- el.style.position = "absolute";
123
+ el.style.position = 'absolute';
122
124
  el.style.left = left + 'px';
123
125
  el.style.top = bottom !== -1 ? 'auto' : top + 'px';
124
126
  el.style.bottom = bottom === -1 ? 'auto' : bottom + 'px';
@@ -128,7 +130,7 @@ export class LibsUiComponentsInputsMentionListComponent {
128
130
  const parentStyles = window.getComputedStyle(nativeParentElement);
129
131
  return {
130
132
  height: parseFloat(parentStyles.lineHeight),
131
- width: parseFloat(parentStyles.fontSize)
133
+ width: parseFloat(parentStyles.fontSize),
132
134
  };
133
135
  }
134
136
  handleActiveItem(event, index) {
@@ -136,7 +138,7 @@ export class LibsUiComponentsInputsMentionListComponent {
136
138
  this.activeIndex.set(index);
137
139
  }
138
140
  scrollToActive() {
139
- if (!this.itemsEl() || (this.itemsEl().length <= this.activeIndex())) {
141
+ if (!this.itemsEl() || this.itemsEl().length <= this.activeIndex()) {
140
142
  return;
141
143
  }
142
144
  this.itemsEl()[this.activeIndex()].nativeElement.scrollIntoView();
@@ -158,9 +160,6 @@ export class LibsUiComponentsInputsMentionListComponent {
158
160
  }
159
161
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsMentionListComponent, decorators: [{
160
162
  type: Component,
161
- args: [{ selector: 'libs_ui-components-inputs-mention-list', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
162
- LibsUiComponentsAvatarComponent,
163
- LibsUiComponentsPopoverComponent
164
- ], template: "<div #element\n class=\"libs-ui-mention-list\"\n [style.zIndex]=\"zIndex()\"\n [class.hidden]=\"hidden()\">\n @for (item of items(); track item) {\n <div #item\n class=\"libs-ui-mention-list-item\"\n [class.libs-ui-mention-list-item-active]=\"$index === activeIndex()\"\n (mousedown)=\"handlerClick($event, $index)\"\n (mouseenter)=\"handleActiveItem($event, $index)\">\n <div class=\"px-[12px] py-[6px] flex items-center\">\n <libs_ui-components-avatar [size]=\"24\"\n [linkAvatar]=\"item.avatar\"\n [linkAvatarError]=\"defaultAvatar()\"\n [getLastTextAfterSpace]=\"true\"\n [textAvatar]=\"item.name\"\n [idGenColor]=\"item.id\" />\n <libs_ui-components-popover [classInclude]=\"'libs-ui-font-h5r'\"\n [type]=\"'text'\"\n [ignoreShowPopover]=\"true\"\n [config]=\"{width: 250}\">\n <!-- // ta.m \u1EA9n show tooltip v\u00EC ch\u01B0a x\u1EED l\u00FD \u0111c v\u1ECB tr\u00ED -->\n {{ item.name + ' (' + item.username + ')' }}\n </libs_ui-components-popover>\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-mention-list{position:absolute;top:-999px;left:-9999px;z-index:1202;float:left;width:315px;padding:4px 0;background-color:#fff;border:solid 1px #e6e8ed;border-radius:5px;max-height:190px;overflow:auto;box-shadow:0 2px 10px 1px #3333331a}.libs-ui-mention-list .libs-ui-mention-list-item{background:#fff;cursor:pointer}.libs-ui-mention-list .libs-ui-mention-list-item:hover,.libs-ui-mention-list .libs-ui-mention-list-item-active{background-color:var(--libs-ui-color-light-3, #f4f8ff)}\n"] }]
163
+ args: [{ selector: 'libs_ui-components-inputs-mention-list', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [LibsUiComponentsAvatarComponent, LibsUiComponentsPopoverComponent], template: "<div #element\n class=\"libs-ui-mention-list\"\n [style.zIndex]=\"zIndex()\"\n [class.hidden]=\"hidden()\">\n @for (item of items(); track item) {\n <div #item\n class=\"libs-ui-mention-list-item\"\n [class.libs-ui-mention-list-item-active]=\"$index === activeIndex()\"\n (mousedown)=\"handlerClick($event, $index)\"\n (mouseenter)=\"handleActiveItem($event, $index)\">\n <div class=\"px-[12px] py-[6px] flex items-center\">\n <libs_ui-components-avatar [size]=\"24\"\n [linkAvatar]=\"item.avatar\"\n [linkAvatarError]=\"defaultAvatar()\"\n [getLastTextAfterSpace]=\"true\"\n [textAvatar]=\"item.name\"\n [idGenColor]=\"item.id\" />\n <libs_ui-components-popover [classInclude]=\"'libs-ui-font-h5r'\"\n [type]=\"'text'\"\n [ignoreShowPopover]=\"true\"\n [config]=\"{width: 250}\">\n <!-- // ta.m \u1EA9n show tooltip v\u00EC ch\u01B0a x\u1EED l\u00FD \u0111c v\u1ECB tr\u00ED -->\n {{ item.name + ' (' + item.username + ')' }}\n </libs_ui-components-popover>\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-mention-list{position:absolute;top:-999px;left:-9999px;z-index:1202;float:left;width:315px;padding:4px 0;background-color:#fff;border:solid 1px #e6e8ed;border-radius:5px;max-height:190px;overflow:auto;box-shadow:0 2px 10px 1px #3333331a}.libs-ui-mention-list .libs-ui-mention-list-item{background:#fff;cursor:pointer}.libs-ui-mention-list .libs-ui-mention-list-item:hover,.libs-ui-mention-list .libs-ui-mention-list-item-active{background-color:var(--libs-ui-color-light-3, #f4f8ff)}\n"] }]
165
164
  }] });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/mention/src/list/list.component.ts","../../../../../../../libs-ui/components/inputs/mention/src/list/list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, model, OnDestroy, OnInit, signal, viewChild, viewChildren } from \"@angular/core\";\nimport { LibsUiComponentsAvatarComponent } from \"@libs-ui/components-avatar\";\nimport { LibsUiComponentsPopoverComponent } from \"@libs-ui/components-popover\";\nimport { set } from \"@libs-ui/utils\";\nimport { fromEvent, Subject, takeUntil } from \"rxjs\";\nimport { getCaretCoordinates } from \"../defines/caret-coords.define\";\nimport { KEY_ENTER } from \"../defines/keyboard.define\";\nimport { getContentEditableCaretCoords, isInputOrTextAreaElement } from \"../defines/utils.define\";\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-mention-list',\n  templateUrl: './list.component.html',\n  styleUrls: ['./list.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LibsUiComponentsAvatarComponent,\n    LibsUiComponentsPopoverComponent\n  ]\n})\nexport class LibsUiComponentsInputsMentionListComponent implements OnInit, OnDestroy {\n\n  // #region PROPERTY\n  public items = signal<Array<Record<string, string | undefined>>>([]);\n  public activeIndex = signal<number>(0);\n  public hidden = signal<boolean>(false);\n  public styleOff = signal<boolean>(false);\n  public parentHandlerKeyDown = signal<((e: Event, element: HTMLInputElement | undefined) => unknown) | undefined>(undefined);\n\n  protected dropUp = signal<boolean>(false);\n\n  private coords = signal<{ top: number, left: number, bottom?: number }>({ top: 0, left: 0, bottom: 0 });\n  private offset = signal<number>(0);\n  private nativeParentElement = signal<HTMLInputElement | undefined>(undefined);\n  private onDestroy = new Subject<void>();\n\n  // #region INPUT\n  labelKey = model<string>('label');\n  zIndex = model<number>(1000);\n  isIframe = model.required<boolean>();\n  defaultAvatar = model<string>();\n\n  /* VIEW CHILD */\n  readonly elementEl = viewChild<ElementRef>('element');\n  readonly itemsEl = viewChildren<ElementRef>('item');\n\n  ngOnInit() {\n    if (this.isIframe()) {\n      this.initEvent(window.parent, 'wheel');\n      this.initEvent(window.parent, 'resize');\n      return;\n    }\n    this.initEvent(window, 'wheel');\n    this.initEvent(window, 'resize');\n  }\n\n  /* FUNCTIONS */\n  private initEvent(element: Window, eventName: string) {\n    fromEvent<Event>(element, eventName).pipe(takeUntil(this.onDestroy)).subscribe((event: Event) => {\n      if (eventName === 'resize' || !this.elementEl()?.nativeElement.contains(event.target)) {\n        this.handlerListenClose(event);\n      }\n    });\n  }\n\n  private handlerListenClose(event: Event) {\n    if (event.target !== this.elementEl()?.nativeElement) {\n      this.hidden.set(true);\n    }\n  }\n\n  // lots of confusion here between relative coordinates and containers\n  position(nativeParentElement: HTMLInputElement, iframe?: HTMLIFrameElement, leftDiv?: number): void {\n    this.nativeParentElement.set(nativeParentElement);\n    if (isInputOrTextAreaElement(nativeParentElement)) {\n      // parent elements need to have postition:relative for this to work correctly?\n      this.coords.set(getCaretCoordinates(nativeParentElement, nativeParentElement.selectionStart));\n      this.coords.update(item => ({\n        ...item,\n        top: nativeParentElement.offsetTop + item.top - nativeParentElement.scrollTop,\n        left: nativeParentElement.offsetLeft + item.left - nativeParentElement.scrollLeft + nativeParentElement.getBoundingClientRect().left\n      }));\n\n      // getCretCoordinates() for text/input elements needs an additional offset to position the list correctly\n      this.offset.set(this.getBlockCursorDimensions(nativeParentElement).height);\n      this.positionElement();\n      return;\n    }\n    if (iframe) {\n      const context: { iframe: HTMLIFrameElement, parent: Element | null, windowParent?: boolean } = { iframe: iframe, parent: window.parent.document.body, windowParent: true };\n      // const rect = iframe.getBoundingClientRect();\n      const caretRelativeToView = getContentEditableCaretCoords(context);\n      const doc = document.documentElement;\n      const scrollLeft = (window.scrollX || doc.scrollLeft) - (doc.clientLeft || 0);\n      this.coords.update(item => ({\n        ...item,\n        left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),\n        bottom: window.parent.innerHeight - caretRelativeToView.top + 18\n      }));\n      if (caretRelativeToView.bottom && caretRelativeToView.bottom !== -1) {\n        this.coords.update(item => ({\n          ...item,\n          bottom: caretRelativeToView.bottom\n        }));\n      }\n      this.positionElement();\n\n      return;\n    }\n    const doc = document.documentElement;\n    const scrollLeft = (window.scrollX || doc.scrollLeft) - (doc.clientLeft || 0);\n    const scrollTop = (window.scrollX || doc.scrollTop) - (doc.clientTop || 0);\n    // bounding rectangles are relative to view, offsets are relative to container?\n    const caretRelativeToView = getContentEditableCaretCoords({ iframe, parent: null });\n\n    this.coords.update(item => ({\n      ...item,\n      top: caretRelativeToView.top - scrollTop + 10,\n      left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),\n      bottom: caretRelativeToView.bottom\n    }))\n    this.positionElement();\n  }\n\n  get ActiveItem() {\n    return this.items()[this.activeIndex()];\n  }\n\n  protected handlerClick(event: Event, index: number) {\n    event.stopPropagation();\n    this.activeIndex.set(index);\n    set(event, 'keyCode', KEY_ENTER);\n    this.parentHandlerKeyDown()?.(event, this.nativeParentElement());\n  }\n\n  activateNextItem() {\n    this.activeIndex.set(this.items().length - 1 > this.activeIndex() ? this.activeIndex() + 1 : this.activeIndex());\n    this.scrollToActive();\n  }\n\n  activatePreviousItem() {\n    this.activeIndex.set(this.activeIndex() > 0 ? this.activeIndex() - 1 : this.activeIndex());\n    this.scrollToActive();\n  }\n\n  private positionElement(left: number = this.coords().left, top: number = this.coords().top, dropUp: boolean = this.dropUp(), bottom: number = this.coords().bottom || 0) {\n    const el = this.elementEl()?.nativeElement;\n\n    top += dropUp ? 0 : this.offset(); // top of list is next line\n    el.style.position = \"absolute\";\n    el.style.left = left + 'px';\n    el.style.top = bottom !== -1 ? 'auto' : top + 'px';\n    el.style.bottom = bottom === -1 ? 'auto' : bottom + 'px';\n    this.nativeParentElement()?.normalize();\n  }\n\n  private getBlockCursorDimensions(nativeParentElement: HTMLInputElement) {\n    const parentStyles = window.getComputedStyle(nativeParentElement);\n\n    return {\n      height: parseFloat(parentStyles.lineHeight),\n      width: parseFloat(parentStyles.fontSize)\n    };\n  }\n\n  protected handleActiveItem(event: Event, index: number) {\n    event.stopPropagation();\n    this.activeIndex.set(index);\n  }\n\n  private scrollToActive() {\n    if (!this.itemsEl() || (this.itemsEl().length <= this.activeIndex())) {\n      return;\n    }\n    this.itemsEl()[this.activeIndex()].nativeElement.scrollIntoView();\n  }\n\n  scrollContent() {\n    setTimeout(() => {\n      const element = this.elementEl();\n      if (element && element.nativeElement) {\n        element.nativeElement.scrollTop = 0;\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n\n}\n","<div #element\n  class=\"libs-ui-mention-list\"\n  [style.zIndex]=\"zIndex()\"\n  [class.hidden]=\"hidden()\">\n  @for (item of items(); track item) {\n    <div #item\n      class=\"libs-ui-mention-list-item\"\n      [class.libs-ui-mention-list-item-active]=\"$index === activeIndex()\"\n      (mousedown)=\"handlerClick($event, $index)\"\n      (mouseenter)=\"handleActiveItem($event, $index)\">\n      <div class=\"px-[12px] py-[6px] flex items-center\">\n        <libs_ui-components-avatar [size]=\"24\"\n          [linkAvatar]=\"item.avatar\"\n          [linkAvatarError]=\"defaultAvatar()\"\n          [getLastTextAfterSpace]=\"true\"\n          [textAvatar]=\"item.name\"\n          [idGenColor]=\"item.id\" />\n        <libs_ui-components-popover [classInclude]=\"'libs-ui-font-h5r'\"\n          [type]=\"'text'\"\n          [ignoreShowPopover]=\"true\"\n          [config]=\"{width: 250}\">\n          <!-- // ta.m ẩn show tooltip vì chưa xử lý đc vị trí -->\n          {{ item.name + ' (' + item.username + ')' }}\n        </libs_ui-components-popover>\n      </div>\n    </div>\n  }\n</div>\n"]}
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/mention/src/list/list.component.ts","../../../../../../../libs-ui/components/inputs/mention/src/list/list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, model, OnDestroy, OnInit, signal, viewChild, viewChildren } from '@angular/core';\nimport { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';\nimport { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { set } from '@libs-ui/utils';\nimport { fromEvent, Subject, takeUntil } from 'rxjs';\nimport { getCaretCoordinates } from '../defines/caret-coords.define';\nimport { KEY_ENTER } from '../defines/keyboard.define';\nimport { getContentEditableCaretCoords, isInputOrTextAreaElement } from '../defines/utils.define';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-mention-list',\n  templateUrl: './list.component.html',\n  styleUrls: ['./list.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [LibsUiComponentsAvatarComponent, LibsUiComponentsPopoverComponent],\n})\nexport class LibsUiComponentsInputsMentionListComponent implements OnInit, OnDestroy {\n  // #region PROPERTY\n  public items = signal<Array<Record<string, string | undefined>>>([]);\n  public activeIndex = signal<number>(0);\n  public hidden = signal<boolean>(false);\n  public styleOff = signal<boolean>(false);\n  public parentHandlerKeyDown = signal<((e: Event, element: HTMLInputElement | undefined) => unknown) | undefined>(undefined);\n\n  protected dropUp = signal<boolean>(false);\n\n  private coords = signal<{ top: number; left: number; bottom?: number }>({ top: 0, left: 0, bottom: 0 });\n  private offset = signal<number>(0);\n  private nativeParentElement = signal<HTMLInputElement | undefined>(undefined);\n  private onDestroy = new Subject<void>();\n\n  // #region INPUT\n  labelKey = model<string>('label');\n  zIndex = model<number>(1000);\n  isIframe = model.required<boolean>();\n  defaultAvatar = model<string>();\n\n  /* VIEW CHILD */\n  readonly elementEl = viewChild<ElementRef>('element');\n  readonly itemsEl = viewChildren<ElementRef>('item');\n\n  ngOnInit() {\n    if (this.isIframe()) {\n      this.initEvent(window.parent, 'wheel');\n      this.initEvent(window.parent, 'resize');\n      return;\n    }\n    this.initEvent(window, 'wheel');\n    this.initEvent(window, 'resize');\n  }\n\n  /* FUNCTIONS */\n  private initEvent(element: Window, eventName: string) {\n    fromEvent<Event>(element, eventName)\n      .pipe(takeUntil(this.onDestroy))\n      .subscribe((event: Event) => {\n        if (eventName === 'resize' || !this.elementEl()?.nativeElement.contains(event.target)) {\n          this.handlerListenClose(event);\n        }\n      });\n  }\n\n  private handlerListenClose(event: Event) {\n    if (event.target !== this.elementEl()?.nativeElement) {\n      this.hidden.set(true);\n    }\n  }\n\n  // lots of confusion here between relative coordinates and containers\n  position(nativeParentElement: HTMLInputElement, iframe?: HTMLIFrameElement, leftDiv?: number): void {\n    this.nativeParentElement.set(nativeParentElement);\n    if (isInputOrTextAreaElement(nativeParentElement)) {\n      // parent elements need to have postition:relative for this to work correctly?\n      this.coords.set(getCaretCoordinates(nativeParentElement, nativeParentElement.selectionStart));\n      this.coords.update((item) => ({\n        ...item,\n        top: nativeParentElement.offsetTop + item.top - nativeParentElement.scrollTop,\n        left: nativeParentElement.offsetLeft + item.left - nativeParentElement.scrollLeft + nativeParentElement.getBoundingClientRect().left,\n      }));\n\n      // getCretCoordinates() for text/input elements needs an additional offset to position the list correctly\n      this.offset.set(this.getBlockCursorDimensions(nativeParentElement).height);\n      this.positionElement();\n      return;\n    }\n    if (iframe) {\n      const context: { iframe: HTMLIFrameElement; parent: Element | null; windowParent?: boolean } = { iframe: iframe, parent: window.parent.document.body, windowParent: true };\n      // const rect = iframe.getBoundingClientRect();\n      const caretRelativeToView = getContentEditableCaretCoords(context);\n      const doc = document.documentElement;\n      const scrollLeft = (window.scrollX || doc.scrollLeft) - (doc.clientLeft || 0);\n      this.coords.update((item) => ({\n        ...item,\n        left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),\n        bottom: window.parent.innerHeight - caretRelativeToView.top + 18,\n      }));\n      if (caretRelativeToView.bottom && caretRelativeToView.bottom !== -1) {\n        this.coords.update((item) => ({\n          ...item,\n          bottom: caretRelativeToView.bottom,\n        }));\n      }\n      this.positionElement();\n\n      return;\n    }\n    const doc = document.documentElement;\n    const scrollLeft = (window.scrollX || doc.scrollLeft) - (doc.clientLeft || 0);\n    const scrollTop = (window.scrollX || doc.scrollTop) - (doc.clientTop || 0);\n    // bounding rectangles are relative to view, offsets are relative to container?\n    const caretRelativeToView = getContentEditableCaretCoords({ iframe, parent: null });\n\n    this.coords.update((item) => ({\n      ...item,\n      top: caretRelativeToView.top - scrollTop + 10,\n      left: caretRelativeToView.left - scrollLeft - (leftDiv || 0),\n      bottom: caretRelativeToView.bottom,\n    }));\n    this.positionElement();\n  }\n\n  get ActiveItem() {\n    return this.items()[this.activeIndex()];\n  }\n\n  protected handlerClick(event: Event, index: number) {\n    event.stopPropagation();\n    this.activeIndex.set(index);\n    set(event as KeyboardEvent, 'keyCode', KEY_ENTER);\n    this.parentHandlerKeyDown()?.(event, this.nativeParentElement());\n  }\n\n  activateNextItem() {\n    this.activeIndex.set(this.items().length - 1 > this.activeIndex() ? this.activeIndex() + 1 : this.activeIndex());\n    this.scrollToActive();\n  }\n\n  activatePreviousItem() {\n    this.activeIndex.set(this.activeIndex() > 0 ? this.activeIndex() - 1 : this.activeIndex());\n    this.scrollToActive();\n  }\n\n  private positionElement(left: number = this.coords().left, top: number = this.coords().top, dropUp: boolean = this.dropUp(), bottom: number = this.coords().bottom || 0) {\n    const el = this.elementEl()?.nativeElement;\n\n    top += dropUp ? 0 : this.offset(); // top of list is next line\n    el.style.position = 'absolute';\n    el.style.left = left + 'px';\n    el.style.top = bottom !== -1 ? 'auto' : top + 'px';\n    el.style.bottom = bottom === -1 ? 'auto' : bottom + 'px';\n    this.nativeParentElement()?.normalize();\n  }\n\n  private getBlockCursorDimensions(nativeParentElement: HTMLInputElement) {\n    const parentStyles = window.getComputedStyle(nativeParentElement);\n\n    return {\n      height: parseFloat(parentStyles.lineHeight),\n      width: parseFloat(parentStyles.fontSize),\n    };\n  }\n\n  protected handleActiveItem(event: Event, index: number) {\n    event.stopPropagation();\n    this.activeIndex.set(index);\n  }\n\n  private scrollToActive() {\n    if (!this.itemsEl() || this.itemsEl().length <= this.activeIndex()) {\n      return;\n    }\n    this.itemsEl()[this.activeIndex()].nativeElement.scrollIntoView();\n  }\n\n  scrollContent() {\n    setTimeout(() => {\n      const element = this.elementEl();\n      if (element && element.nativeElement) {\n        element.nativeElement.scrollTop = 0;\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n","<div #element\n  class=\"libs-ui-mention-list\"\n  [style.zIndex]=\"zIndex()\"\n  [class.hidden]=\"hidden()\">\n  @for (item of items(); track item) {\n    <div #item\n      class=\"libs-ui-mention-list-item\"\n      [class.libs-ui-mention-list-item-active]=\"$index === activeIndex()\"\n      (mousedown)=\"handlerClick($event, $index)\"\n      (mouseenter)=\"handleActiveItem($event, $index)\">\n      <div class=\"px-[12px] py-[6px] flex items-center\">\n        <libs_ui-components-avatar [size]=\"24\"\n          [linkAvatar]=\"item.avatar\"\n          [linkAvatarError]=\"defaultAvatar()\"\n          [getLastTextAfterSpace]=\"true\"\n          [textAvatar]=\"item.name\"\n          [idGenColor]=\"item.id\" />\n        <libs_ui-components-popover [classInclude]=\"'libs-ui-font-h5r'\"\n          [type]=\"'text'\"\n          [ignoreShowPopover]=\"true\"\n          [config]=\"{width: 250}\">\n          <!-- // ta.m ẩn show tooltip vì chưa xử lý đc vị trí -->\n          {{ item.name + ' (' + item.username + ')' }}\n        </libs_ui-components-popover>\n      </div>\n    </div>\n  }\n</div>\n"]}