@libs-ui/utils 0.2.298 → 0.2.299
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dom.d.ts +6 -4
- package/esm2022/dom.mjs +30 -29
- package/fesm2022/libs-ui-utils.mjs +27 -26
- package/fesm2022/libs-ui-utils.mjs.map +1 -1
- package/package.json +2 -2
package/dom.d.ts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { Renderer2 } from
|
|
2
|
-
import { IBoundingClientRect } from
|
|
3
|
-
import { Subject } from
|
|
4
|
-
import Delta from
|
|
1
|
+
import { Renderer2 } from '@angular/core';
|
|
2
|
+
import { IBoundingClientRect } from '@libs-ui/interfaces-types';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import Delta from 'quill-delta';
|
|
5
|
+
import DeviceDetector from 'device-detector-js';
|
|
6
|
+
export declare const getDeviceInfo: () => DeviceDetector.DeviceDetectorResult;
|
|
5
7
|
export declare const getPlatFromBrowser: () => string;
|
|
6
8
|
export declare const getDocumentByString: (htmlStr: string) => Document;
|
|
7
9
|
export declare const cloneIBoundingClientRect: (rect: IBoundingClientRect) => IBoundingClientRect;
|
package/esm2022/dom.mjs
CHANGED
|
@@ -1,27 +1,16 @@
|
|
|
1
|
-
import { finalize, fromEvent, mergeMap, startWith, takeUntil, tap } from
|
|
2
|
-
import Quill from
|
|
3
|
-
import { decodeEscapeHtml } from
|
|
1
|
+
import { finalize, fromEvent, mergeMap, startWith, takeUntil, tap, } from 'rxjs';
|
|
2
|
+
import Quill from 'quill';
|
|
3
|
+
import { decodeEscapeHtml } from './format-text';
|
|
4
|
+
import DeviceDetector from 'device-detector-js';
|
|
5
|
+
const deviceDetector = new DeviceDetector();
|
|
4
6
|
const parser = new DOMParser();
|
|
5
7
|
const quill = new Quill(document.createElement('div'));
|
|
8
|
+
export const getDeviceInfo = () => {
|
|
9
|
+
return deviceDetector.parse(window.navigator.userAgent);
|
|
10
|
+
};
|
|
6
11
|
export const getPlatFromBrowser = () => {
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
let match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
|
|
10
|
-
if (/trident/i.test(match[1])) {
|
|
11
|
-
tem = /\brv[ :]+(\d+)/g.exec(userAgent) || [];
|
|
12
|
-
return 'IE ' + (tem[1] || '');
|
|
13
|
-
}
|
|
14
|
-
if (match[1] === 'Chrome') {
|
|
15
|
-
tem = userAgent.match(/\b(OPR|Edge)\/(\d+)/);
|
|
16
|
-
if (tem !== null) {
|
|
17
|
-
return tem.slice(1).join(' ').replace('OPR', 'Opera');
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
match = match[2] ? [match[1], match[2]] : [navigator.appName, navigator.appVersion, '-?'];
|
|
21
|
-
if ((tem = userAgent.match(/version\/(\d+)/i)) !== null) {
|
|
22
|
-
match.splice(1, 1, tem[1]);
|
|
23
|
-
}
|
|
24
|
-
return match.join(' ');
|
|
12
|
+
const info = getDeviceInfo();
|
|
13
|
+
return `${info.client?.name} ${info.client?.version}`;
|
|
25
14
|
};
|
|
26
15
|
export const getDocumentByString = (htmlStr) => {
|
|
27
16
|
return parser.parseFromString(htmlStr, 'text/html');
|
|
@@ -32,7 +21,7 @@ export const cloneIBoundingClientRect = (rect) => {
|
|
|
32
21
|
left: rect['left'],
|
|
33
22
|
width: rect['width'],
|
|
34
23
|
height: rect['height'],
|
|
35
|
-
bottom: rect['bottom']
|
|
24
|
+
bottom: rect['bottom'],
|
|
36
25
|
};
|
|
37
26
|
};
|
|
38
27
|
export const setStylesElement = (el, styles, render2) => {
|
|
@@ -71,7 +60,10 @@ export const checkViewInScreen = (container, element, elementScroll, maxTopLeft)
|
|
|
71
60
|
const limitLeft = leftContainer + scrollLeftContainer + widthContainer;
|
|
72
61
|
const maxTopItem = top + (maxTopLeft?.top || 0);
|
|
73
62
|
const maxLeftItem = left + (maxTopLeft?.left || 0);
|
|
74
|
-
if (topContainer <= maxTopItem &&
|
|
63
|
+
if (topContainer <= maxTopItem &&
|
|
64
|
+
maxTopItem <= limitTop &&
|
|
65
|
+
leftContainer <= maxLeftItem &&
|
|
66
|
+
maxLeftItem <= limitLeft) {
|
|
75
67
|
return true;
|
|
76
68
|
}
|
|
77
69
|
return false;
|
|
@@ -85,7 +77,10 @@ export const checkMouseOverInContainer = (mousePosition, element, rect) => {
|
|
|
85
77
|
const limitLeft = left + width;
|
|
86
78
|
const limitTop = top + height;
|
|
87
79
|
const { clientX, clientY } = mousePosition;
|
|
88
|
-
if (left <= clientX &&
|
|
80
|
+
if (left <= clientX &&
|
|
81
|
+
clientX <= limitLeft &&
|
|
82
|
+
top <= clientY &&
|
|
83
|
+
clientY <= limitTop) {
|
|
89
84
|
return true;
|
|
90
85
|
}
|
|
91
86
|
return false;
|
|
@@ -103,8 +98,12 @@ export const getDragEventByElement = (config) => {
|
|
|
103
98
|
document.body.classList.remove('!cursor-grabbing');
|
|
104
99
|
clearTimeout(timer);
|
|
105
100
|
};
|
|
106
|
-
fromEvent(config.elementMouseDown, 'mouseleave')
|
|
107
|
-
|
|
101
|
+
fromEvent(config.elementMouseDown, 'mouseleave')
|
|
102
|
+
.pipe(tap(() => document.body.classList.remove('cursor-pointer')), takeUntil(config.onDestroy))
|
|
103
|
+
.subscribe();
|
|
104
|
+
fromEvent(config.elementMouseDown, 'mouseenter')
|
|
105
|
+
.pipe(tap(() => document.body.classList.add('cursor-pointer')), takeUntil(config.onDestroy))
|
|
106
|
+
.subscribe();
|
|
108
107
|
const mouseDown = fromEvent(config.elementMouseDown, 'mousedown').pipe(tap((e) => {
|
|
109
108
|
e.stopPropagation();
|
|
110
109
|
addClass();
|
|
@@ -119,13 +118,15 @@ export const getDragEventByElement = (config) => {
|
|
|
119
118
|
e.stopPropagation();
|
|
120
119
|
config.functionMouseMove?.(e);
|
|
121
120
|
}), takeUntil(mouseup));
|
|
122
|
-
return mouseDown.pipe(mergeMap((e) => config.isStartWithMouseDownEvent
|
|
121
|
+
return mouseDown.pipe(mergeMap((e) => config.isStartWithMouseDownEvent
|
|
122
|
+
? mousemove.pipe(startWith(e))
|
|
123
|
+
: mousemove), takeUntil(config.onDestroy), finalize(removeClass));
|
|
123
124
|
};
|
|
124
125
|
export const getHTMLFromQuill = (delta) => {
|
|
125
126
|
delta.ops.forEach((op) => {
|
|
126
127
|
if (op.insert) {
|
|
127
128
|
if (typeof op.insert === 'string') {
|
|
128
|
-
op.insert = op.insert.replace(/\n/g,
|
|
129
|
+
op.insert = op.insert.replace(/\n/g, '<br>');
|
|
129
130
|
}
|
|
130
131
|
}
|
|
131
132
|
});
|
|
@@ -133,4 +134,4 @@ export const getHTMLFromQuill = (delta) => {
|
|
|
133
134
|
const htmlText = quill.root.firstElementChild?.innerHTML;
|
|
134
135
|
return decodeEscapeHtml(htmlText || '');
|
|
135
136
|
};
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../../libs-ui/utils/src/dom.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Renderer2 } from \"@angular/core\";\nimport { IBoundingClientRect } from \"@libs-ui/interfaces-types\";\nimport { finalize, fromEvent, mergeMap, startWith, Subject, takeUntil, tap } from \"rxjs\";\nimport Quill from \"quill\";\n  import Delta from \"quill-delta\";\n  import { decodeEscapeHtml } from \"./format-text\";\n\nconst parser = new DOMParser();\nconst quill = new Quill(document.createElement('div'));\n\nexport const getPlatFromBrowser = () => {\n  const userAgent = navigator.userAgent;\n  let tem;\n  let match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\\/))\\/?\\s*(\\d+)/i) || [];\n\n  if (/trident/i.test(match[1])) {\n    tem = /\\brv[ :]+(\\d+)/g.exec(userAgent) || [];\n\n    return 'IE ' + (tem[1] || '');\n  }\n  if (match[1] === 'Chrome') {\n    tem = userAgent.match(/\\b(OPR|Edge)\\/(\\d+)/);\n    if (tem !== null) {\n      return tem.slice(1).join(' ').replace('OPR', 'Opera');\n    }\n\n  }\n  match = match[2] ? [match[1], match[2]] : [navigator.appName, navigator.appVersion, '-?'];\n  if ((tem = userAgent.match(/version\\/(\\d+)/i)) !== null) {\n    match.splice(1, 1, tem[1]);\n  }\n\n  return match.join(' ');\n}\n\nexport const getDocumentByString = (htmlStr: string): Document => {\n\n  return parser.parseFromString(htmlStr, 'text/html');\n}\n\nexport const cloneIBoundingClientRect = (rect: IBoundingClientRect): IBoundingClientRect => {\n  return {\n    top: rect['top'],\n    left: rect['left'],\n    width: rect['width'],\n    height: rect['height'],\n    bottom: rect['bottom']\n  };\n}\n\nexport const setStylesElement = (el: HTMLElement, styles: Record<string, string>, render2: Renderer2): void => {\n  Object.keys(styles).forEach((key: string) => render2.setStyle(el, key, styles[key]));\n}\n\nexport const getViewport = (win: Window = window): { width: number; height: number } => {\n  const doc = win.document.documentElement,\n    body = win.document.getElementsByTagName('body')[0],\n    w = win.innerWidth || doc.clientWidth || body.clientWidth,\n    h = win.innerHeight || doc.clientHeight || body.clientHeight;\n\n  return { width: w, height: h };\n}\n\nexport const setCaretPosition = (element: HTMLTextAreaElement | HTMLInputElement, position: number): void => {\n  if (!element || !element.setSelectionRange) {\n    return;\n  }\n  element.focus();\n  element.setSelectionRange(position, position);\n}\n\nexport const checkViewInScreen = (container: HTMLElement, element: HTMLElement, elementScroll?: HTMLElement, maxTopLeft?: { top?: number, left?: number }): boolean => {\n  if (!container || !element) {\n    return false;\n  }\n\n  const rectContainer = cloneIBoundingClientRect(container.getBoundingClientRect());\n\n  if (elementScroll) {\n    const rectElementScroll = elementScroll.getBoundingClientRect();\n\n    rectContainer['left'] = rectElementScroll.left;\n    rectContainer['top'] = rectElementScroll.top;\n\n  }\n\n  const rectElement = element.getBoundingClientRect();\n  const { left, top } = rectElement;\n  const topContainer = rectContainer['top'];\n  const leftContainer = rectContainer['left'];\n  const widthContainer = rectContainer['width'];\n  const heightContainer = rectContainer['height'];\n  const scrollTopContainer = container.scrollTop;\n  const scrollLeftContainer = container.scrollLeft;\n  const limitTop = topContainer + scrollTopContainer + heightContainer;\n  const limitLeft = leftContainer + scrollLeftContainer + widthContainer;\n\n  const maxTopItem = top + (maxTopLeft?.top || 0);\n  const maxLeftItem = left + (maxTopLeft?.left || 0);\n\n  if (topContainer <= maxTopItem && maxTopItem <= limitTop && leftContainer <= maxLeftItem && maxLeftItem <= limitLeft) {\n    return true;\n  }\n\n  return false;\n};\n\nexport const checkMouseOverInContainer = (mousePosition: { clientX: number; clientY: number }, element?: HTMLElement, rect?: DOMRect): boolean => {\n  if (!element && !rect) {\n    return false;\n  }\n  const rectElement = rect || element?.getBoundingClientRect() || {} as DOMRect;\n  const { left, top, width, height } = rectElement;\n  const limitLeft = left + width;\n  const limitTop = top + height;\n  const { clientX, clientY } = mousePosition;\n  if (left <= clientX && clientX <= limitLeft && top <= clientY && clientY <= limitTop) {\n    return true;\n  }\n\n  return false;\n};\n\nexport const getDragEventByElement = (config: {\n  elementMouseDown: HTMLElement;\n  functionMouseDown?: (event: MouseEvent) => void;\n  isStartWithMouseDownEvent?: boolean;\n  elementMouseMove?: HTMLElement;\n  functionMouseMove?: (event: MouseEvent) => void;\n  elementMouseUp?: HTMLElement,\n  functionMouseUp?: (event: MouseEvent) => void;\n  onDestroy: Subject<any>;\n}) => {\n  let timer: number;\n  const addClass = () => {\n    timer = setTimeout(() => {\n      document.body.classList.add('!select-none');\n      document.body.classList.add('!cursor-grabbing');\n    }, 250);\n\n  };\n  const removeClass = () => {\n    document.body.classList.remove('!select-none');\n    document.body.classList.remove('!cursor-grabbing');\n    clearTimeout(timer);\n  }\n  fromEvent(config.elementMouseDown, 'mouseleave').pipe(tap(() => document.body.classList.remove('cursor-pointer')), takeUntil(config.onDestroy)).subscribe();\n  fromEvent(config.elementMouseDown, 'mouseenter').pipe(tap(() => document.body.classList.add('cursor-pointer')), takeUntil(config.onDestroy)).subscribe();\n\n  const mouseDown = fromEvent<MouseEvent>(config.elementMouseDown, 'mousedown').pipe(\n    tap((e) => {\n      e.stopPropagation();\n      addClass();\n      config.functionMouseDown?.(e);\n    })\n  );\n  const mouseup = fromEvent<MouseEvent>(config.elementMouseUp || document, 'mouseup').pipe(\n    tap((e) => {\n      e.stopPropagation();\n      removeClass();\n      config.functionMouseUp?.(e);\n    })\n  );\n\n  const mousemove = fromEvent<MouseEvent>(config.elementMouseMove || document, 'mousemove').pipe(\n    tap((e) => {\n      e.stopPropagation();\n      config.functionMouseMove?.(e);\n    }),\n    takeUntil(mouseup)\n  );\n\n  return mouseDown.pipe(\n    mergeMap((e: MouseEvent) => config.isStartWithMouseDownEvent ? mousemove.pipe(startWith(e)) : mousemove),\n    takeUntil(config.onDestroy),\n    finalize(removeClass)\n  );\n}\n\nexport const getHTMLFromQuill = (delta: Delta): string => {\n  delta.ops.forEach((op) => {\n    if (op.insert) {\n      if (typeof op.insert === 'string') {\n        op.insert = op.insert.replace(/\\n/g, \"<br>\");\n      }\n    }\n  });\n  quill.setContents(delta);\n  const htmlText = quill.root.firstElementChild?.innerHTML;\n  return decodeEscapeHtml(htmlText || '');\n}\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../../libs-ui/utils/src/dom.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Renderer2 } from '@angular/core';\nimport { IBoundingClientRect } from '@libs-ui/interfaces-types';\nimport {\n  finalize,\n  fromEvent,\n  mergeMap,\n  startWith,\n  Subject,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport Quill from 'quill';\nimport Delta from 'quill-delta';\nimport { decodeEscapeHtml } from './format-text';\nimport DeviceDetector from 'device-detector-js';\n\nconst deviceDetector = new DeviceDetector();\nconst parser = new DOMParser();\nconst quill = new Quill(document.createElement('div'));\n\nexport const getDeviceInfo = () => {\n  return deviceDetector.parse(window.navigator.userAgent);\n};\nexport const getPlatFromBrowser = () => {\n  const info = getDeviceInfo();\n  return `${info.client?.name} ${info.client?.version}`;\n};\n\nexport const getDocumentByString = (htmlStr: string): Document => {\n  return parser.parseFromString(htmlStr, 'text/html');\n};\n\nexport const cloneIBoundingClientRect = (\n  rect: IBoundingClientRect\n): IBoundingClientRect => {\n  return {\n    top: rect['top'],\n    left: rect['left'],\n    width: rect['width'],\n    height: rect['height'],\n    bottom: rect['bottom'],\n  };\n};\n\nexport const setStylesElement = (\n  el: HTMLElement,\n  styles: Record<string, string>,\n  render2: Renderer2\n): void => {\n  Object.keys(styles).forEach((key: string) =>\n    render2.setStyle(el, key, styles[key])\n  );\n};\n\nexport const getViewport = (\n  win: Window = window\n): { width: number; height: number } => {\n  const doc = win.document.documentElement,\n    body = win.document.getElementsByTagName('body')[0],\n    w = win.innerWidth || doc.clientWidth || body.clientWidth,\n    h = win.innerHeight || doc.clientHeight || body.clientHeight;\n\n  return { width: w, height: h };\n};\n\nexport const setCaretPosition = (\n  element: HTMLTextAreaElement | HTMLInputElement,\n  position: number\n): void => {\n  if (!element || !element.setSelectionRange) {\n    return;\n  }\n  element.focus();\n  element.setSelectionRange(position, position);\n};\n\nexport const checkViewInScreen = (\n  container: HTMLElement,\n  element: HTMLElement,\n  elementScroll?: HTMLElement,\n  maxTopLeft?: { top?: number; left?: number }\n): boolean => {\n  if (!container || !element) {\n    return false;\n  }\n\n  const rectContainer = cloneIBoundingClientRect(\n    container.getBoundingClientRect()\n  );\n\n  if (elementScroll) {\n    const rectElementScroll = elementScroll.getBoundingClientRect();\n\n    rectContainer['left'] = rectElementScroll.left;\n    rectContainer['top'] = rectElementScroll.top;\n  }\n\n  const rectElement = element.getBoundingClientRect();\n  const { left, top } = rectElement;\n  const topContainer = rectContainer['top'];\n  const leftContainer = rectContainer['left'];\n  const widthContainer = rectContainer['width'];\n  const heightContainer = rectContainer['height'];\n  const scrollTopContainer = container.scrollTop;\n  const scrollLeftContainer = container.scrollLeft;\n  const limitTop = topContainer + scrollTopContainer + heightContainer;\n  const limitLeft = leftContainer + scrollLeftContainer + widthContainer;\n\n  const maxTopItem = top + (maxTopLeft?.top || 0);\n  const maxLeftItem = left + (maxTopLeft?.left || 0);\n\n  if (\n    topContainer <= maxTopItem &&\n    maxTopItem <= limitTop &&\n    leftContainer <= maxLeftItem &&\n    maxLeftItem <= limitLeft\n  ) {\n    return true;\n  }\n\n  return false;\n};\n\nexport const checkMouseOverInContainer = (\n  mousePosition: { clientX: number; clientY: number },\n  element?: HTMLElement,\n  rect?: DOMRect\n): boolean => {\n  if (!element && !rect) {\n    return false;\n  }\n  const rectElement =\n    rect || element?.getBoundingClientRect() || ({} as DOMRect);\n  const { left, top, width, height } = rectElement;\n  const limitLeft = left + width;\n  const limitTop = top + height;\n  const { clientX, clientY } = mousePosition;\n  if (\n    left <= clientX &&\n    clientX <= limitLeft &&\n    top <= clientY &&\n    clientY <= limitTop\n  ) {\n    return true;\n  }\n\n  return false;\n};\n\nexport const getDragEventByElement = (config: {\n  elementMouseDown: HTMLElement;\n  functionMouseDown?: (event: MouseEvent) => void;\n  isStartWithMouseDownEvent?: boolean;\n  elementMouseMove?: HTMLElement;\n  functionMouseMove?: (event: MouseEvent) => void;\n  elementMouseUp?: HTMLElement;\n  functionMouseUp?: (event: MouseEvent) => void;\n  onDestroy: Subject<any>;\n}) => {\n  let timer: number;\n  const addClass = () => {\n    timer = setTimeout(() => {\n      document.body.classList.add('!select-none');\n      document.body.classList.add('!cursor-grabbing');\n    }, 250);\n  };\n  const removeClass = () => {\n    document.body.classList.remove('!select-none');\n    document.body.classList.remove('!cursor-grabbing');\n    clearTimeout(timer);\n  };\n  fromEvent(config.elementMouseDown, 'mouseleave')\n    .pipe(\n      tap(() => document.body.classList.remove('cursor-pointer')),\n      takeUntil(config.onDestroy)\n    )\n    .subscribe();\n  fromEvent(config.elementMouseDown, 'mouseenter')\n    .pipe(\n      tap(() => document.body.classList.add('cursor-pointer')),\n      takeUntil(config.onDestroy)\n    )\n    .subscribe();\n\n  const mouseDown = fromEvent<MouseEvent>(\n    config.elementMouseDown,\n    'mousedown'\n  ).pipe(\n    tap((e) => {\n      e.stopPropagation();\n      addClass();\n      config.functionMouseDown?.(e);\n    })\n  );\n  const mouseup = fromEvent<MouseEvent>(\n    config.elementMouseUp || document,\n    'mouseup'\n  ).pipe(\n    tap((e) => {\n      e.stopPropagation();\n      removeClass();\n      config.functionMouseUp?.(e);\n    })\n  );\n\n  const mousemove = fromEvent<MouseEvent>(\n    config.elementMouseMove || document,\n    'mousemove'\n  ).pipe(\n    tap((e) => {\n      e.stopPropagation();\n      config.functionMouseMove?.(e);\n    }),\n    takeUntil(mouseup)\n  );\n\n  return mouseDown.pipe(\n    mergeMap((e: MouseEvent) =>\n      config.isStartWithMouseDownEvent\n        ? mousemove.pipe(startWith(e))\n        : mousemove\n    ),\n    takeUntil(config.onDestroy),\n    finalize(removeClass)\n  );\n};\n\nexport const getHTMLFromQuill = (delta: Delta): string => {\n  delta.ops.forEach((op) => {\n    if (op.insert) {\n      if (typeof op.insert === 'string') {\n        op.insert = op.insert.replace(/\\n/g, '<br>');\n      }\n    }\n  });\n  quill.setContents(delta);\n  const htmlText = quill.root.firstElementChild?.innerHTML;\n  return decodeEscapeHtml(htmlText || '');\n};\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { fromEvent, tap, takeUntil, mergeMap, startWith, finalize, Observable, Subject, filter } from 'rxjs';
|
|
2
2
|
import Quill from 'quill';
|
|
3
|
+
import DeviceDetector from 'device-detector-js';
|
|
3
4
|
import CryptoES from 'crypto-es';
|
|
4
5
|
import { HttpParams } from '@angular/common/http';
|
|
5
6
|
import { isSignal, TemplateRef, ElementRef, signal, InjectionToken } from '@angular/core';
|
|
@@ -223,27 +224,15 @@ const removeEmoji = (text) => {
|
|
|
223
224
|
return text.replace(patternEmoji(), '');
|
|
224
225
|
};
|
|
225
226
|
|
|
227
|
+
const deviceDetector = new DeviceDetector();
|
|
226
228
|
const parser = new DOMParser();
|
|
227
229
|
const quill = new Quill(document.createElement('div'));
|
|
230
|
+
const getDeviceInfo = () => {
|
|
231
|
+
return deviceDetector.parse(window.navigator.userAgent);
|
|
232
|
+
};
|
|
228
233
|
const getPlatFromBrowser = () => {
|
|
229
|
-
const
|
|
230
|
-
|
|
231
|
-
let match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
|
|
232
|
-
if (/trident/i.test(match[1])) {
|
|
233
|
-
tem = /\brv[ :]+(\d+)/g.exec(userAgent) || [];
|
|
234
|
-
return 'IE ' + (tem[1] || '');
|
|
235
|
-
}
|
|
236
|
-
if (match[1] === 'Chrome') {
|
|
237
|
-
tem = userAgent.match(/\b(OPR|Edge)\/(\d+)/);
|
|
238
|
-
if (tem !== null) {
|
|
239
|
-
return tem.slice(1).join(' ').replace('OPR', 'Opera');
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
match = match[2] ? [match[1], match[2]] : [navigator.appName, navigator.appVersion, '-?'];
|
|
243
|
-
if ((tem = userAgent.match(/version\/(\d+)/i)) !== null) {
|
|
244
|
-
match.splice(1, 1, tem[1]);
|
|
245
|
-
}
|
|
246
|
-
return match.join(' ');
|
|
234
|
+
const info = getDeviceInfo();
|
|
235
|
+
return `${info.client?.name} ${info.client?.version}`;
|
|
247
236
|
};
|
|
248
237
|
const getDocumentByString = (htmlStr) => {
|
|
249
238
|
return parser.parseFromString(htmlStr, 'text/html');
|
|
@@ -254,7 +243,7 @@ const cloneIBoundingClientRect = (rect) => {
|
|
|
254
243
|
left: rect['left'],
|
|
255
244
|
width: rect['width'],
|
|
256
245
|
height: rect['height'],
|
|
257
|
-
bottom: rect['bottom']
|
|
246
|
+
bottom: rect['bottom'],
|
|
258
247
|
};
|
|
259
248
|
};
|
|
260
249
|
const setStylesElement = (el, styles, render2) => {
|
|
@@ -293,7 +282,10 @@ const checkViewInScreen = (container, element, elementScroll, maxTopLeft) => {
|
|
|
293
282
|
const limitLeft = leftContainer + scrollLeftContainer + widthContainer;
|
|
294
283
|
const maxTopItem = top + (maxTopLeft?.top || 0);
|
|
295
284
|
const maxLeftItem = left + (maxTopLeft?.left || 0);
|
|
296
|
-
if (topContainer <= maxTopItem &&
|
|
285
|
+
if (topContainer <= maxTopItem &&
|
|
286
|
+
maxTopItem <= limitTop &&
|
|
287
|
+
leftContainer <= maxLeftItem &&
|
|
288
|
+
maxLeftItem <= limitLeft) {
|
|
297
289
|
return true;
|
|
298
290
|
}
|
|
299
291
|
return false;
|
|
@@ -307,7 +299,10 @@ const checkMouseOverInContainer = (mousePosition, element, rect) => {
|
|
|
307
299
|
const limitLeft = left + width;
|
|
308
300
|
const limitTop = top + height;
|
|
309
301
|
const { clientX, clientY } = mousePosition;
|
|
310
|
-
if (left <= clientX &&
|
|
302
|
+
if (left <= clientX &&
|
|
303
|
+
clientX <= limitLeft &&
|
|
304
|
+
top <= clientY &&
|
|
305
|
+
clientY <= limitTop) {
|
|
311
306
|
return true;
|
|
312
307
|
}
|
|
313
308
|
return false;
|
|
@@ -325,8 +320,12 @@ const getDragEventByElement = (config) => {
|
|
|
325
320
|
document.body.classList.remove('!cursor-grabbing');
|
|
326
321
|
clearTimeout(timer);
|
|
327
322
|
};
|
|
328
|
-
fromEvent(config.elementMouseDown, 'mouseleave')
|
|
329
|
-
|
|
323
|
+
fromEvent(config.elementMouseDown, 'mouseleave')
|
|
324
|
+
.pipe(tap(() => document.body.classList.remove('cursor-pointer')), takeUntil(config.onDestroy))
|
|
325
|
+
.subscribe();
|
|
326
|
+
fromEvent(config.elementMouseDown, 'mouseenter')
|
|
327
|
+
.pipe(tap(() => document.body.classList.add('cursor-pointer')), takeUntil(config.onDestroy))
|
|
328
|
+
.subscribe();
|
|
330
329
|
const mouseDown = fromEvent(config.elementMouseDown, 'mousedown').pipe(tap((e) => {
|
|
331
330
|
e.stopPropagation();
|
|
332
331
|
addClass();
|
|
@@ -341,13 +340,15 @@ const getDragEventByElement = (config) => {
|
|
|
341
340
|
e.stopPropagation();
|
|
342
341
|
config.functionMouseMove?.(e);
|
|
343
342
|
}), takeUntil(mouseup));
|
|
344
|
-
return mouseDown.pipe(mergeMap((e) => config.isStartWithMouseDownEvent
|
|
343
|
+
return mouseDown.pipe(mergeMap((e) => config.isStartWithMouseDownEvent
|
|
344
|
+
? mousemove.pipe(startWith(e))
|
|
345
|
+
: mousemove), takeUntil(config.onDestroy), finalize(removeClass));
|
|
345
346
|
};
|
|
346
347
|
const getHTMLFromQuill = (delta) => {
|
|
347
348
|
delta.ops.forEach((op) => {
|
|
348
349
|
if (op.insert) {
|
|
349
350
|
if (typeof op.insert === 'string') {
|
|
350
|
-
op.insert = op.insert.replace(/\n/g,
|
|
351
|
+
op.insert = op.insert.replace(/\n/g, '<br>');
|
|
351
352
|
}
|
|
352
353
|
}
|
|
353
354
|
});
|
|
@@ -2757,5 +2758,5 @@ const createUniqueRandomIntGenerator = (min, max) => {
|
|
|
2757
2758
|
* Generated bundle index. Do not edit.
|
|
2758
2759
|
*/
|
|
2759
2760
|
|
|
2760
|
-
export { AudioExtList, CHARACTER_DATA_EMPTY, COMMUNICATE_MICRO_KEY_GET_ALL_MESSAGE, COMMUNICATE_MICRO_PREFIX_TYPE, DEFAULT_START_PAGE_0, DocumentExtList, ENCODE_URI_PATTERN, ERROR_MESSAGE_EMPTY_VALID, ERROR_MESSAGE_MAX_LENGTH, ERROR_MESSAGE_MAX_VALID, ERROR_MESSAGE_MIN_LENGTH, ERROR_MESSAGE_MIN_VALID, ERROR_MESSAGE_PATTEN_VALID, ExcelExtList, ImageExtList, LINK_IMAGE_ERROR_TOKEN_INJECT, PROCESS_BAR_STANDARD_CONFIG_DEFAULT_TOKEN_INJECT, PROCESS_BAR_STEPS_CONFIG_DEFAULT_TOKEN_INJECT, UtilsCache, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, UtilsHttpParamsRequest, UtilsHttpParamsRequestInstance, UtilsKeyCodeConstant, UtilsLanguageConstants, UtilsUrlSearchParams, VideoExtList, base64Decode, base64Encode, capitalize, checkMouseOverInContainer, checkViewInScreen, cloneDeep, cloneIBoundingClientRect, colorContrastFromOrigin, colorStepContrastFromOrigin, convertBase64ToBlob, convertBlobToFile, convertFileToBase64, convertFileToBase64_ObjectUrl, convertObjectToSignal, convertSignalToObject, convertUrlToFile, createUniqueRandomIntGenerator, decodeEscapeHtml, decodeURI, decrypt, decrypt3rd, deleteUnicode, downloadFileByUrl, downloadFileByUrlUseXmlRequest, downloadImageFromELement, encodeURI, encrypt, encrypt3rd, endCodeUrl, escapeHtml, firstLetterToUpperCase, formatDate, formatNumber, formatTextCompare, fullNameFormat, generateInterface, get, getColorById, getDayjs, getDocumentByString, getDragEventByElement, getFileExtension, getHTMLFromQuill, getKeyCacheByArrayObject, getLabelBySizeFile, getPlatFromBrowser, getSmartAxisScale, getViewport, groupBy, highlightByKeyword, isDifferenceDay, isDifferenceMonth, isDifferenceYear, isEmbedFrame, isEmpty, isEqual, isIncludeAudioExtList, isIncludeDocumentExtList, isIncludeImageExtList, isIncludeVideoExtList, isNil, isTypeAudio, isTypeFile, isTypeImage, isTypeVideo, keyBy, listColorDefine, md5, omitBy, patternAccount, patternDomain, patternEmail, patternEmoji, patternEncodeUri, patternGetFieldByRuleFieldReplace, patternHostUrl, patternKey, patternMobilePhone, patternName, patternNameProfile, patternNameSpecial, patternNameUtf8, patternNumber, patternPem, patternPhone, patternPhoneNormal, patternRuleFieldReplace, patternTax, patternUrl, protectString, range, removeEmoji, revealString, rgbToHex, set, setCaretPosition, setDefaultTimeZone, setKeyCrypto, setKeyCrypto3rd, setStylesElement, uniqBy, updateFunctionCheckEmbedFrame, updateFunctionFormatDate, updateFunctionXssFilter, uppercaseByPosition, uuid, viewDataNumberByLanguage, xssFilter };
|
|
2761
|
+
export { AudioExtList, CHARACTER_DATA_EMPTY, COMMUNICATE_MICRO_KEY_GET_ALL_MESSAGE, COMMUNICATE_MICRO_PREFIX_TYPE, DEFAULT_START_PAGE_0, DocumentExtList, ENCODE_URI_PATTERN, ERROR_MESSAGE_EMPTY_VALID, ERROR_MESSAGE_MAX_LENGTH, ERROR_MESSAGE_MAX_VALID, ERROR_MESSAGE_MIN_LENGTH, ERROR_MESSAGE_MIN_VALID, ERROR_MESSAGE_PATTEN_VALID, ExcelExtList, ImageExtList, LINK_IMAGE_ERROR_TOKEN_INJECT, PROCESS_BAR_STANDARD_CONFIG_DEFAULT_TOKEN_INJECT, PROCESS_BAR_STEPS_CONFIG_DEFAULT_TOKEN_INJECT, UtilsCache, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, UtilsHttpParamsRequest, UtilsHttpParamsRequestInstance, UtilsKeyCodeConstant, UtilsLanguageConstants, UtilsUrlSearchParams, VideoExtList, base64Decode, base64Encode, capitalize, checkMouseOverInContainer, checkViewInScreen, cloneDeep, cloneIBoundingClientRect, colorContrastFromOrigin, colorStepContrastFromOrigin, convertBase64ToBlob, convertBlobToFile, convertFileToBase64, convertFileToBase64_ObjectUrl, convertObjectToSignal, convertSignalToObject, convertUrlToFile, createUniqueRandomIntGenerator, decodeEscapeHtml, decodeURI, decrypt, decrypt3rd, deleteUnicode, downloadFileByUrl, downloadFileByUrlUseXmlRequest, downloadImageFromELement, encodeURI, encrypt, encrypt3rd, endCodeUrl, escapeHtml, firstLetterToUpperCase, formatDate, formatNumber, formatTextCompare, fullNameFormat, generateInterface, get, getColorById, getDayjs, getDeviceInfo, getDocumentByString, getDragEventByElement, getFileExtension, getHTMLFromQuill, getKeyCacheByArrayObject, getLabelBySizeFile, getPlatFromBrowser, getSmartAxisScale, getViewport, groupBy, highlightByKeyword, isDifferenceDay, isDifferenceMonth, isDifferenceYear, isEmbedFrame, isEmpty, isEqual, isIncludeAudioExtList, isIncludeDocumentExtList, isIncludeImageExtList, isIncludeVideoExtList, isNil, isTypeAudio, isTypeFile, isTypeImage, isTypeVideo, keyBy, listColorDefine, md5, omitBy, patternAccount, patternDomain, patternEmail, patternEmoji, patternEncodeUri, patternGetFieldByRuleFieldReplace, patternHostUrl, patternKey, patternMobilePhone, patternName, patternNameProfile, patternNameSpecial, patternNameUtf8, patternNumber, patternPem, patternPhone, patternPhoneNormal, patternRuleFieldReplace, patternTax, patternUrl, protectString, range, removeEmoji, revealString, rgbToHex, set, setCaretPosition, setDefaultTimeZone, setKeyCrypto, setKeyCrypto3rd, setStylesElement, uniqBy, updateFunctionCheckEmbedFrame, updateFunctionFormatDate, updateFunctionXssFilter, uppercaseByPosition, uuid, viewDataNumberByLanguage, xssFilter };
|
|
2761
2762
|
//# sourceMappingURL=libs-ui-utils.mjs.map
|