@epam/statgpt-shared-toolkit 0.2.0-rc.4 → 0.2.0-rc.40

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/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d={CHAT:"/api/chat"},C="CUSTOM_PERIOD",c={decimal:"0.0",decimalSymbol:",",digitGroupingSymbol:" "},T="application/json",_="Content-Type",r="Api-Key",A="X-CONVERSATION-ID",i="Ocp-Apim-Subscription-Key",I={BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504},s="onboarding",u="share";var R=(e=>(e.MONTH="month",e.DAY="day",e))(R||{}),l=(e=>(e.UK="uk",e.EN="en",e))(l||{}),S=(e=>(e.IN="in",e.BETWEEN="between",e))(S||{});function D(e,t){const n=e.split("/")[0],E=t.split("/").pop();return`${n}/${E}`}const g=e=>(e==null?void 0:e.toLowerCase().replace(/[^\p{L}\p{N}]+/gu,"-").replace(/^-+|-+$/g,"").replace(/-/g," "))||"";function y(e,t){return`${e==null?void 0:e[0]}/${t}/${e==null?void 0:e[1]}`}const H=(e,t)=>(Math.round(e*10**t)/10**t).toString(),p=(e,t)=>{const n=(t==null?void 0:t.decimal)||c.decimal,E=(t==null?void 0:t.decimalSymbol)||c.decimalSymbol,O=(t==null?void 0:t.digitGroupingSymbol)??c.digitGroupingSymbol,o=Number(e);if(o==null||Number.isNaN(o)||e===null||e==="")return"";const N=n.replace("0.",""),a=`${n==="0"?Math.trunc(o):H(o,N.length)} `.split(".");return a[0]=a[0].replace(/(\d)(?=(\d\d\d)+(?!\d))/g,`$1${O}`),`${a.join(E)}`},h=e=>isNaN(Date.parse(e))?null:new Date(e),P=(e,t,n)=>{const E={[_]:(t==null?void 0:t.contentType)||T};return t!=null&&t.jwt?E.Authorization=`Bearer ${t.jwt}`:e&&(E[r]=e),t!=null&&t.chatReference&&(E[A]=t.chatReference),{...E,...n}},b=e=>{const t={...e};return t[r]&&(t[r]=t[r].substring(0,8)+"...[REDACTED]"),t.Authorization&&(t.Authorization="Bearer [REDACTED]"),t[i]&&(t[i]=t[i].substring(0,8)+"...[REDACTED]"),t},B=e=>({"Content-Type":`multipart/form-data; boundary=${e}`}),M=e=>(e==null?void 0:e.toLowerCase())==="true",L=async(e,t,n)=>await fetch(e,{method:n.method||"GET",headers:t,body:n.body?JSON.stringify(n.body):void 0}),U=(e,t)=>{var n,E;return(E=(n=e==null?void 0:e.split("/"))==null?void 0:n.filter(O=>O!==t))==null?void 0:E.join("/")},$=e=>e.map(t=>({...t,name:t.name.split(/-\d+$/)[0]}));exports.API_KEY_HEADER=r;exports.API_ROUTES=d;exports.APPLICATION_JSON=T;exports.CONTENT_TYPE_HEADER=_;exports.CUSTOM_PERIOD=C;exports.CalendarResolution=R;exports.HTTP_ERROR_CODES=I;exports.Locale=l;exports.OCP_APIM_SUBSCRIPTION_KEY_HEADER=i;exports.ONBOARDING_MODEL_POSTFIX=s;exports.QueryFilterType=S;exports.SHARE_CONVERSATION_ROUTE=u;exports.X_CONVERSATION_ID_HEADER=A;exports.cleanConversationNames=$;exports.defaultFormatNumbers=c;exports.formatNumberBySign=p;exports.getClearedConversationName=g;exports.getConversationId=y;exports.getConversationNavPath=D;exports.getConversationUrlWithoutLocale=U;exports.getHeaders=P;exports.getMultipartHeaders=B;exports.getTimePeriod=h;exports.parseBoolean=M;exports.sanitizeHeaders=b;exports.sendRequest=L;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I={CHAT:"/api/chat"},N="CUSTOM_PERIOD",a={decimal:"0.0",decimalSymbol:",",digitGroupingSymbol:" "},u="application/json",O="Content-Type",c="Api-Key",A="X-CONVERSATION-ID",l="Ocp-Apim-Subscription-Key",S={BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504},C="onboarding",h="share";class p extends Error{constructor(e){super(e.message),this.isHttpError=!0,this.name="HttpError",this.code=e.code,this.status=e.status,this.details=e.details}}function D(t){return typeof t=="object"&&t!==null&&t.isHttpError===!0&&typeof t.status=="number"&&typeof t.message=="string"&&(t.code===void 0||typeof t.code=="string")}var _=(t=>(t.MONTH="month",t.DAY="day",t))(_||{}),d=(t=>(t.UK="uk",t.EN="en",t))(d||{}),R=(t=>(t.IN="in",t.BETWEEN="between",t))(R||{});function y(t,e){const n=t.split("/")[0],r=e.split("/").pop();return`${n}/${r}`}const H=t=>(t==null?void 0:t.toLowerCase().replace(/[^\p{L}\p{N}]+/gu,"-").replace(/^-+|-+$/g,"").replace(/-/g," "))||"";function f(t,e){return`${t==null?void 0:t[0]}/${e}/${t==null?void 0:t[1]}`}const P=(t,e)=>(Math.round(t*10**e)/10**e).toString(),U=(t,e)=>{const n=(e==null?void 0:e.decimal)||a.decimal,r=(e==null?void 0:e.decimalSymbol)||a.decimalSymbol,o=(e==null?void 0:e.digitGroupingSymbol)??a.digitGroupingSymbol,i=Number(t);if(i==null||Number.isNaN(i)||t===null||t==="")return"";const s=n.replace("0.",""),T=`${n==="0"?Math.trunc(i):P(i,s.length)} `.split(".");return T[0]=T[0].replace(/(\d)(?=(\d\d\d)+(?!\d))/g,`$1${o}`),`${T.join(r)}`},b=t=>isNaN(Date.parse(t))?null:new Date(t),v=(t,e,n)=>{const r={[O]:(e==null?void 0:e.contentType)||u};return e!=null&&e.jwt?r.Authorization=`Bearer ${e.jwt}`:t&&(r[c]=t),e!=null&&e.chatReference&&(r[A]=e.chatReference),{...r,...n}},B=t=>{const e={...t};return e[c]&&(e[c]=e[c].substring(0,8)+"...[REDACTED]"),e.Authorization&&(e.Authorization="Bearer [REDACTED]"),e[l]&&(e[l]=e[l].substring(0,8)+"...[REDACTED]"),e},L=t=>({"Content-Type":`multipart/form-data; boundary=${t}`}),M=t=>(t==null?void 0:t.toLowerCase())==="true",m=async(t,e,n)=>await fetch(t,{method:n.method||"GET",headers:e,body:n.body?JSON.stringify(n.body):void 0}),$=(t,e)=>{var n,r;return(r=(n=t==null?void 0:t.split("/"))==null?void 0:n.filter(o=>o!==e))==null?void 0:r.join("/")},x=t=>t.map(e=>({...e,name:e.name.split(/-\d+$/)[0]})),w=new Set([")","]","}",">",",",".","!","?",":",";"]);function g(t){let e=t.length;for(;e>0&&w.has(t[e-1]);)e--;return e===t.length?{cleanUrl:t,trailing:""}:{cleanUrl:t.slice(0,e),trailing:t.slice(e)}}function G(t){if(!t)return[{type:"text",value:""}];const e=[];let n=0;for(const r of t.matchAll(/\bhttps?:\/\/[^\s<>"']+/gi)){const o=r[0],i=r.index??0;i>n&&e.push({type:"text",value:t.slice(n,i)});const{cleanUrl:s,trailing:E}=g(o);s?e.push({type:"link",value:s}):e.push({type:"text",value:o}),E&&e.push({type:"text",value:E}),n=i+o.length}return n<t.length&&e.push({type:"text",value:t.slice(n)}),e.length?e:[{type:"text",value:t}]}exports.API_KEY_HEADER=c;exports.API_ROUTES=I;exports.APPLICATION_JSON=u;exports.CONTENT_TYPE_HEADER=O;exports.CUSTOM_PERIOD=N;exports.CalendarResolution=_;exports.HTTP_ERROR_CODES=S;exports.HttpError=p;exports.Locale=d;exports.OCP_APIM_SUBSCRIPTION_KEY_HEADER=l;exports.ONBOARDING_MODEL_POSTFIX=C;exports.QueryFilterType=R;exports.SHARE_CONVERSATION_ROUTE=h;exports.X_CONVERSATION_ID_HEADER=A;exports.cleanConversationNames=x;exports.defaultFormatNumbers=a;exports.formatNumberBySign=U;exports.getClearedConversationName=H;exports.getConversationId=f;exports.getConversationNavPath=y;exports.getConversationUrlWithoutLocale=$;exports.getHeaders=v;exports.getMultipartHeaders=L;exports.getTimePeriod=b;exports.isHttpError=D;exports.linkifyText=G;exports.parseBoolean=M;exports.sanitizeHeaders=B;exports.sendRequest=m;exports.splitTrailingPunctuation=g;
package/index.mjs CHANGED
@@ -1,10 +1,10 @@
1
- const N = {
1
+ const I = {
2
2
  CHAT: "/api/chat"
3
- }, u = "CUSTOM_PERIOD", O = {
3
+ }, S = "CUSTOM_PERIOD", a = {
4
4
  decimal: "0.0",
5
5
  decimalSymbol: ",",
6
6
  digitGroupingSymbol: " "
7
- }, R = "application/json", l = "Content-Type", r = "Api-Key", _ = "X-CONVERSATION-ID", T = "Ocp-Apim-Subscription-Key", C = {
7
+ }, T = "application/json", d = "Content-Type", l = "Api-Key", A = "X-CONVERSATION-ID", u = "Ocp-Apim-Subscription-Key", N = {
8
8
  BAD_REQUEST: 400,
9
9
  UNAUTHORIZED: 401,
10
10
  FORBIDDEN: 403,
@@ -16,71 +16,115 @@ const N = {
16
16
  BAD_GATEWAY: 502,
17
17
  SERVICE_UNAVAILABLE: 503,
18
18
  GATEWAY_TIMEOUT: 504
19
- }, g = "onboarding", s = "share";
20
- var d = /* @__PURE__ */ ((t) => (t.MONTH = "month", t.DAY = "day", t))(d || {}), S = /* @__PURE__ */ ((t) => (t.UK = "uk", t.EN = "en", t))(S || {}), a = /* @__PURE__ */ ((t) => (t.IN = "in", t.BETWEEN = "between", t))(a || {});
21
- function y(t, n) {
22
- const e = t.split("/")[0], c = n.split("/").pop();
23
- return `${e}/${c}`;
19
+ }, D = "onboarding", y = "share";
20
+ class C extends Error {
21
+ constructor(e) {
22
+ super(e.message), this.isHttpError = !0, this.name = "HttpError", this.code = e.code, this.status = e.status, this.details = e.details;
23
+ }
24
24
  }
25
- const h = (t) => (t == null ? void 0 : t.toLowerCase().replace(/[^\p{L}\p{N}]+/gu, "-").replace(/^-+|-+$/g, "").replace(/-/g, " ")) || "";
26
- function p(t, n) {
27
- return `${t == null ? void 0 : t[0]}/${n}/${t == null ? void 0 : t[1]}`;
25
+ function f(t) {
26
+ return typeof t == "object" && t !== null && t.isHttpError === !0 && typeof t.status == "number" && typeof t.message == "string" && (t.code === void 0 || typeof t.code == "string");
28
27
  }
29
- const D = (t, n) => (Math.round(t * 10 ** n) / 10 ** n).toString(), H = (t, n) => {
30
- const e = (n == null ? void 0 : n.decimal) || O.decimal, c = (n == null ? void 0 : n.decimalSymbol) || O.decimalSymbol, i = (n == null ? void 0 : n.digitGroupingSymbol) ?? O.digitGroupingSymbol, E = Number(t);
31
- if (E == null || Number.isNaN(E) || t === null || t === "")
28
+ var g = /* @__PURE__ */ ((t) => (t.MONTH = "month", t.DAY = "day", t))(g || {}), O = /* @__PURE__ */ ((t) => (t.UK = "uk", t.EN = "en", t))(O || {}), h = /* @__PURE__ */ ((t) => (t.IN = "in", t.BETWEEN = "between", t))(h || {});
29
+ function H(t, e) {
30
+ const n = t.split("/")[0], r = e.split("/").pop();
31
+ return `${n}/${r}`;
32
+ }
33
+ const U = (t) => (t == null ? void 0 : t.toLowerCase().replace(/[^\p{L}\p{N}]+/gu, "-").replace(/^-+|-+$/g, "").replace(/-/g, " ")) || "";
34
+ function b(t, e) {
35
+ return `${t == null ? void 0 : t[0]}/${e}/${t == null ? void 0 : t[1]}`;
36
+ }
37
+ const R = (t, e) => (Math.round(t * 10 ** e) / 10 ** e).toString(), $ = (t, e) => {
38
+ const n = (e == null ? void 0 : e.decimal) || a.decimal, r = (e == null ? void 0 : e.decimalSymbol) || a.decimalSymbol, i = (e == null ? void 0 : e.digitGroupingSymbol) ?? a.digitGroupingSymbol, c = Number(t);
39
+ if (c == null || Number.isNaN(c) || t === null || t === "")
32
40
  return "";
33
- const A = e.replace("0.", ""), o = `${e === "0" ? Math.trunc(E) : D(E, A.length)} `.split(".");
34
- return o[0] = o[0].replace(
41
+ const s = n.replace("0.", ""), E = `${n === "0" ? Math.trunc(c) : R(c, s.length)} `.split(".");
42
+ return E[0] = E[0].replace(
35
43
  /(\d)(?=(\d\d\d)+(?!\d))/g,
36
44
  `$1${i}`
37
- ), `${o.join(c)}`;
38
- }, $ = (t) => isNaN(Date.parse(t)) ? null : new Date(t), b = (t, n, e) => {
39
- const c = {
40
- [l]: (n == null ? void 0 : n.contentType) || R
45
+ ), `${E.join(r)}`;
46
+ }, x = (t) => isNaN(Date.parse(t)) ? null : new Date(t), B = (t, e, n) => {
47
+ const r = {
48
+ [d]: (e == null ? void 0 : e.contentType) || T
41
49
  };
42
- return n != null && n.jwt ? c.Authorization = `Bearer ${n.jwt}` : t && (c[r] = t), n != null && n.chatReference && (c[_] = n.chatReference), { ...c, ...e };
43
- }, B = (t) => {
44
- const n = { ...t };
45
- return n[r] && (n[r] = n[r].substring(0, 8) + "...[REDACTED]"), n.Authorization && (n.Authorization = "Bearer [REDACTED]"), n[T] && (n[T] = n[T].substring(0, 8) + "...[REDACTED]"), n;
46
- }, L = (t) => ({
50
+ return e != null && e.jwt ? r.Authorization = `Bearer ${e.jwt}` : t && (r[l] = t), e != null && e.chatReference && (r[A] = e.chatReference), { ...r, ...n };
51
+ }, L = (t) => {
52
+ const e = { ...t };
53
+ return e[l] && (e[l] = e[l].substring(0, 8) + "...[REDACTED]"), e.Authorization && (e.Authorization = "Bearer [REDACTED]"), e[u] && (e[u] = e[u].substring(0, 8) + "...[REDACTED]"), e;
54
+ }, M = (t) => ({
47
55
  "Content-Type": `multipart/form-data; boundary=${t}`
48
- }), M = (t) => (t == null ? void 0 : t.toLowerCase()) === "true", U = async (t, n, e) => await fetch(t, {
49
- method: e.method || "GET",
50
- headers: n,
51
- body: e.body ? JSON.stringify(e.body) : void 0
52
- }), G = (t, n) => {
53
- var e, c;
54
- return (c = (e = t == null ? void 0 : t.split("/")) == null ? void 0 : e.filter((i) => i !== n)) == null ? void 0 : c.join("/");
55
- }, w = (t) => t.map((n) => ({
56
- ...n,
57
- name: n.name.split(/-\d+$/)[0]
58
- }));
56
+ }), v = (t) => (t == null ? void 0 : t.toLowerCase()) === "true", w = async (t, e, n) => await fetch(t, {
57
+ method: n.method || "GET",
58
+ headers: e,
59
+ body: n.body ? JSON.stringify(n.body) : void 0
60
+ }), G = (t, e) => {
61
+ var n, r;
62
+ return (r = (n = t == null ? void 0 : t.split("/")) == null ? void 0 : n.filter((i) => i !== e)) == null ? void 0 : r.join("/");
63
+ }, Y = (t) => t.map((e) => ({
64
+ ...e,
65
+ name: e.name.split(/-\d+$/)[0]
66
+ })), p = /* @__PURE__ */ new Set([
67
+ ")",
68
+ "]",
69
+ "}",
70
+ ">",
71
+ ",",
72
+ ".",
73
+ "!",
74
+ "?",
75
+ ":",
76
+ ";"
77
+ ]);
78
+ function _(t) {
79
+ let e = t.length;
80
+ for (; e > 0 && p.has(t[e - 1]); )
81
+ e--;
82
+ return e === t.length ? { cleanUrl: t, trailing: "" } : {
83
+ cleanUrl: t.slice(0, e),
84
+ trailing: t.slice(e)
85
+ };
86
+ }
87
+ function j(t) {
88
+ if (!t) return [{ type: "text", value: "" }];
89
+ const e = [];
90
+ let n = 0;
91
+ for (const r of t.matchAll(/\bhttps?:\/\/[^\s<>"']+/gi)) {
92
+ const i = r[0], c = r.index ?? 0;
93
+ c > n && e.push({ type: "text", value: t.slice(n, c) });
94
+ const { cleanUrl: s, trailing: o } = _(i);
95
+ s ? e.push({ type: "link", value: s }) : e.push({ type: "text", value: i }), o && e.push({ type: "text", value: o }), n = c + i.length;
96
+ }
97
+ return n < t.length && e.push({ type: "text", value: t.slice(n) }), e.length ? e : [{ type: "text", value: t }];
98
+ }
59
99
  export {
60
- r as API_KEY_HEADER,
61
- N as API_ROUTES,
62
- R as APPLICATION_JSON,
63
- l as CONTENT_TYPE_HEADER,
64
- u as CUSTOM_PERIOD,
65
- d as CalendarResolution,
66
- C as HTTP_ERROR_CODES,
67
- S as Locale,
68
- T as OCP_APIM_SUBSCRIPTION_KEY_HEADER,
69
- g as ONBOARDING_MODEL_POSTFIX,
70
- a as QueryFilterType,
71
- s as SHARE_CONVERSATION_ROUTE,
72
- _ as X_CONVERSATION_ID_HEADER,
73
- w as cleanConversationNames,
74
- O as defaultFormatNumbers,
75
- H as formatNumberBySign,
76
- h as getClearedConversationName,
77
- p as getConversationId,
78
- y as getConversationNavPath,
100
+ l as API_KEY_HEADER,
101
+ I as API_ROUTES,
102
+ T as APPLICATION_JSON,
103
+ d as CONTENT_TYPE_HEADER,
104
+ S as CUSTOM_PERIOD,
105
+ g as CalendarResolution,
106
+ N as HTTP_ERROR_CODES,
107
+ C as HttpError,
108
+ O as Locale,
109
+ u as OCP_APIM_SUBSCRIPTION_KEY_HEADER,
110
+ D as ONBOARDING_MODEL_POSTFIX,
111
+ h as QueryFilterType,
112
+ y as SHARE_CONVERSATION_ROUTE,
113
+ A as X_CONVERSATION_ID_HEADER,
114
+ Y as cleanConversationNames,
115
+ a as defaultFormatNumbers,
116
+ $ as formatNumberBySign,
117
+ U as getClearedConversationName,
118
+ b as getConversationId,
119
+ H as getConversationNavPath,
79
120
  G as getConversationUrlWithoutLocale,
80
- b as getHeaders,
81
- L as getMultipartHeaders,
82
- $ as getTimePeriod,
83
- M as parseBoolean,
84
- B as sanitizeHeaders,
85
- U as sendRequest
121
+ B as getHeaders,
122
+ M as getMultipartHeaders,
123
+ x as getTimePeriod,
124
+ f as isHttpError,
125
+ j as linkifyText,
126
+ v as parseBoolean,
127
+ L as sanitizeHeaders,
128
+ w as sendRequest,
129
+ _ as splitTrailingPunctuation
86
130
  };
@@ -0,0 +1,14 @@
1
+ export interface HttpErrorPayload<D = unknown> {
2
+ status: number;
3
+ code?: string;
4
+ message: string;
5
+ details?: D;
6
+ }
7
+ export declare class HttpError<D = unknown> extends Error {
8
+ readonly code?: string;
9
+ readonly status: number;
10
+ readonly details?: D;
11
+ readonly isHttpError = true;
12
+ constructor(payload: HttpErrorPayload<D>);
13
+ }
14
+ export declare function isHttpError(e: unknown): e is HttpError;
package/models/index.d.ts CHANGED
@@ -7,3 +7,4 @@ export * from './request-options';
7
7
  export * from './time-range';
8
8
  export * from './onboarding-schema';
9
9
  export * from './format-numbers-type';
10
+ export * from './errors/http-error';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@epam/statgpt-shared-toolkit",
3
- "version": "0.2.0-rc.4",
3
+ "version": "0.2.0-rc.40",
4
4
  "license": "MIT",
5
5
  "exports": {
6
6
  ".": {
package/utils/index.d.ts CHANGED
@@ -9,3 +9,4 @@ export * from './send-request';
9
9
  export * from './conversation-url';
10
10
  export * from './conversation-mapping';
11
11
  export * from './format-numbers';
12
+ export * from './linkify/linkify';
@@ -0,0 +1,18 @@
1
+ type LinkifiedPart = {
2
+ type: 'text';
3
+ value: string;
4
+ } | {
5
+ type: 'link';
6
+ value: string;
7
+ };
8
+ export declare function splitTrailingPunctuation(url: string): {
9
+ cleanUrl: string;
10
+ trailing: string;
11
+ };
12
+ /**
13
+ * Splits input into text + link parts.
14
+ * - Only http/https are linkified.
15
+ * - Trailing punctuation is split off into a following text part.
16
+ */
17
+ export declare function linkifyText(input: string): LinkifiedPart[];
18
+ export {};