@epam/statgpt-shared-toolkit 0.2.0-rc.49 → 0.2.0-rc.50

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