react-luminus-components 1.3.269 → 1.4.2
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/dist/.vite/manifest.json +38 -38
- package/dist/FormDisabledProvider-BJFDwkr3.cjs +1 -0
- package/dist/{FormDisabledProvider-DxRJDkfY.js → FormDisabledProvider-DLeRXjZ8.js} +1 -1
- package/dist/contexts.cjs.js +1 -1
- package/dist/contexts.es.js +43 -43
- package/dist/hooks/useGetApiData/useGetApiData.d.ts +3 -3
- package/dist/hooks.cjs.js +1 -1
- package/dist/hooks.es.js +15 -15
- package/dist/layout.cjs.js +1 -1
- package/dist/layout.es.js +19 -19
- package/dist/main.cjs.js +2 -2
- package/dist/main.es.js +1529 -1529
- package/dist/models/index.d.ts +2 -0
- package/dist/models/types/useGetApiData/ReloadDataType.d.ts +2 -0
- package/dist/models/types/useGetApiData/ReloadDataWithReturnType.d.ts +2 -0
- package/dist/nivo-bar.es-BRHkg8Ew.cjs +279 -0
- package/dist/nivo-bar.es-wC2Yrmiv.js +26490 -0
- package/dist/useGetApiData-CI_mLKxJ.cjs +1 -0
- package/dist/useGetApiData-DtJQa5kO.js +61 -0
- package/dist/useLocalStorageState-BFc8Gc8H.cjs +1 -0
- package/dist/{useRenderDraggableInPortal-DmwANWh2.cjs → useRenderDraggableInPortal-QPCaw-E_.cjs} +1 -1
- package/dist/utils.cjs.js +1 -1
- package/dist/utils.es.js +20 -20
- package/package.json +1 -1
- package/dist/FormDisabledProvider-DDKE_eKy.cjs +0 -1
- package/dist/main.es-BabJ-geZ.cjs +0 -2538
- package/dist/main.es-C8xStyzA.js +0 -207708
- package/dist/useGetApiData-C-BddvcC.cjs +0 -1
- package/dist/useGetApiData-CBEnvOV4.js +0 -57
- package/dist/useLocalStorageState-DXUUXO06.cjs +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const i=require("./nivo-bar.es-BRHkg8Ew.cjs"),t=require("react");require("react-router-dom");require("react-dom");require("react-hook-form");require("react-flexmonster");require("@azure/msal-browser");require("@azure/msal-react");const n={loadOnInit:!0,silent:!1,enabled:!0,nullStateBeforeLoad:!0,nullStateOnFail:!1},v=(s,{loadOnInit:c=n.loadOnInit,enabled:d=n.enabled,silent:o=n.silent,nullStateBeforeLoad:f=n.nullStateBeforeLoad,nullStateOnFail:g=n.nullStateOnFail,customApiUrl:y,customBearerToken:R,dataTransformer:u}=n)=>{const C=i.useAxios({silent:o,customToken:R,differentBaseUrl:y}),[S,D]=t.useState(!1),{startLoading:L,stopLoading:b}=t.useContext(i.LoadingContext),$=t.useRef(0),{isAuthenticated:q}=i.useAuth(),k=t.useCallback(e=>{L(e),D(()=>!0)},[L]),p=t.useCallback(e=>{b(e),D(()=>!1)},[b]),[w,l]=t.useState(null),a=t.useCallback(async(e,x)=>{if(!q()||d===!1)return null;!o&&k(`loadData-${s}-${x}`),f&&l(null);let A;try{const r=await C.get(s,{signal:e}),h=u?u(r.data):r.data;l(h),A=h}catch(r){throw g&&l(null),r}finally{!o&&p(`loadData-${s}-${x}`)}return A},[q,d,o,k,s,f,C,u,g,p]),B=t.useCallback(async()=>{a()},[a]),O=t.useCallback(async()=>a(),[a]);return t.useEffect(()=>{if(c===!1)return;const e=new AbortController;return a(e.signal,++$.current),()=>{e.abort()}},[a,c]),{data:w,setData:l,reloadData:B,isLoading:S,reloadDataWithReturn:O}};exports.useGetApiData=v;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { aj as I, al as j, b2 as v } from "./nivo-bar.es-wC2Yrmiv.js";
|
|
2
|
+
import { useState as A, useContext as E, useRef as F, useCallback as e, useEffect as G } from "react";
|
|
3
|
+
import "react-router-dom";
|
|
4
|
+
import "react-dom";
|
|
5
|
+
import "react-hook-form";
|
|
6
|
+
import "react-flexmonster";
|
|
7
|
+
import "@azure/msal-browser";
|
|
8
|
+
import "@azure/msal-react";
|
|
9
|
+
const o = {
|
|
10
|
+
loadOnInit: !0,
|
|
11
|
+
silent: !1,
|
|
12
|
+
enabled: !0,
|
|
13
|
+
nullStateBeforeLoad: !0,
|
|
14
|
+
nullStateOnFail: !1
|
|
15
|
+
}, N = (n, { loadOnInit: u = o.loadOnInit, enabled: c = o.enabled, silent: s = o.silent, nullStateBeforeLoad: d = o.nullStateBeforeLoad, nullStateOnFail: f = o.nullStateOnFail, customApiUrl: $, customBearerToken: w, dataTransformer: i } = o) => {
|
|
16
|
+
const p = I({ silent: s, customToken: w, differentBaseUrl: $ }), [O, g] = A(!1), { startLoading: m, stopLoading: L } = E(j), R = F(0), { isAuthenticated: D } = v(), x = e((t) => {
|
|
17
|
+
m(t), g(() => !0);
|
|
18
|
+
}, [m]), C = e((t) => {
|
|
19
|
+
L(t), g(() => !1);
|
|
20
|
+
}, [L]), [S, l] = A(null), a = e(async (t, b) => {
|
|
21
|
+
if (!D() || c === !1)
|
|
22
|
+
return null;
|
|
23
|
+
!s && x(`loadData-${n}-${b}`), d && l(null);
|
|
24
|
+
let h;
|
|
25
|
+
try {
|
|
26
|
+
const r = await p.get(n, {
|
|
27
|
+
signal: t
|
|
28
|
+
}), y = i ? i(r.data) : r.data;
|
|
29
|
+
l(y), h = y;
|
|
30
|
+
} catch (r) {
|
|
31
|
+
throw f && l(null), r;
|
|
32
|
+
} finally {
|
|
33
|
+
!s && C(`loadData-${n}-${b}`);
|
|
34
|
+
}
|
|
35
|
+
return h;
|
|
36
|
+
}, [
|
|
37
|
+
D,
|
|
38
|
+
c,
|
|
39
|
+
s,
|
|
40
|
+
x,
|
|
41
|
+
n,
|
|
42
|
+
d,
|
|
43
|
+
p,
|
|
44
|
+
i,
|
|
45
|
+
f,
|
|
46
|
+
C
|
|
47
|
+
]), k = e(async () => {
|
|
48
|
+
a();
|
|
49
|
+
}, [a]), B = e(async () => a(), [a]);
|
|
50
|
+
return G(() => {
|
|
51
|
+
if (u === !1)
|
|
52
|
+
return;
|
|
53
|
+
const t = new AbortController();
|
|
54
|
+
return a(t.signal, ++R.current), () => {
|
|
55
|
+
t.abort();
|
|
56
|
+
};
|
|
57
|
+
}, [a, u]), { data: S, setData: l, reloadData: k, isLoading: O, reloadDataWithReturn: B };
|
|
58
|
+
};
|
|
59
|
+
export {
|
|
60
|
+
N as u
|
|
61
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const a=require("react"),l=(t,c)=>{const s=a.useCallback(()=>{const e=localStorage.getItem(t);return e!=null&&e!=="undefined"?JSON.parse(e):c},[c,t]),[o,r]=a.useState(s);a.useEffect(()=>{localStorage.setItem(t,JSON.stringify(o))},[t,o]);const n=a.useCallback(()=>{r(s)},[s]);return[o,r,n]};exports.useLocalStorageState=l;
|
package/dist/{useRenderDraggableInPortal-DmwANWh2.cjs → useRenderDraggableInPortal-QPCaw-E_.cjs}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const n=require("react"),P=require("react-router-dom"),S=require("react-dom"),b=()=>{const[o,e]=P.useSearchParams(),r=n.useCallback((u,s)=>{o.get(u)!==s&&e(c=>(s===null&&c.delete(u),c.get(u)===s||c.set(u,s??""),c),{replace:!0})},[e,o]);return{searchParams:o,setSearch:r}},f="\0",y=(o,e,r)=>{const{searchParams:u,setSearch:s}=b(),c=n.useCallback(t=>{if(typeof t=="object"){if(r&&r==="date"||!r&&t instanceof Date){if(!(t instanceof Date))throw new Error("Tried to setQueryState of type Date to non-date.");return t.toISOString()}return JSON.stringify(t)}return t.toString()},[r]),l=n.useMemo(()=>c(e),[e,c]),m=n.useMemo(()=>u.get(o),[o,u]),h=n.useMemo(()=>{const t=m;if(t===f)return null;const a=t?Number(t):e;let i=Number.isNaN(a)?typeof e:"number";switch(i==="object"&&e instanceof Date&&(i="date"),r??i){case"number":return a;case"string":return t??e;case"boolean":return t==="true";case"object":return t?JSON.parse(t):e;case"date":return t?new Date(t):e;default:throw console.error(r,i),new Error(`useSearchQueryState is not implemented for type ${typeof(r??i)}.`)}},[e,m,r]),g=n.useCallback(t=>{let a;typeof t=="function"?a=t(h):a=t;const i=c(a);if(e===a||i===l){s(o,null);return}if(a===null){s(o,f);return}s(o,i)},[e,l,c,o,s,h]);return[h,g]},M=o=>{const e=n.useMemo(()=>Math.floor(Math.random()*900)+100,[]),r=n.useMemo(()=>btoa(o.toString()??""),[o]),u=n.useMemo(()=>`employeePhotos?personalNumber=${e}${r}&small=false`,[e,r]),s=n.useMemo(()=>`employeePhotos?personalNumber=${e}${r}&small=true`,[e,r]);return{photoPath:u,photoPathSm:s}},
|
|
1
|
+
"use strict";const n=require("react"),P=require("react-router-dom"),S=require("react-dom"),b=()=>{const[o,e]=P.useSearchParams(),r=n.useCallback((u,s)=>{o.get(u)!==s&&e(c=>(s===null&&c.delete(u),c.get(u)===s||c.set(u,s??""),c),{replace:!0})},[e,o]);return{searchParams:o,setSearch:r}},f="\0",y=(o,e,r)=>{const{searchParams:u,setSearch:s}=b(),c=n.useCallback(t=>{if(typeof t=="object"){if(r&&r==="date"||!r&&t instanceof Date){if(!(t instanceof Date))throw new Error("Tried to setQueryState of type Date to non-date.");return t.toISOString()}return JSON.stringify(t)}return t.toString()},[r]),l=n.useMemo(()=>c(e),[e,c]),m=n.useMemo(()=>u.get(o),[o,u]),h=n.useMemo(()=>{const t=m;if(t===f)return null;const a=t?Number(t):e;let i=Number.isNaN(a)?typeof e:"number";switch(i==="object"&&e instanceof Date&&(i="date"),r??i){case"number":return a;case"string":return t??e;case"boolean":return t==="true";case"object":return t?JSON.parse(t):e;case"date":return t?new Date(t):e;default:throw console.error(r,i),new Error(`useSearchQueryState is not implemented for type ${typeof(r??i)}.`)}},[e,m,r]),g=n.useCallback(t=>{let a;typeof t=="function"?a=t(h):a=t;const i=c(a);if(e===a||i===l){s(o,null);return}if(a===null){s(o,f);return}s(o,i)},[e,l,c,o,s,h]);return[h,g]},M=o=>{const e=n.useMemo(()=>Math.floor(Math.random()*900)+100,[]),r=n.useMemo(()=>btoa(o.toString()??""),[o]),u=n.useMemo(()=>`employeePhotos?personalNumber=${e}${r}&small=false`,[e,r]),s=n.useMemo(()=>`employeePhotos?personalNumber=${e}${r}&small=true`,[e,r]);return{photoPath:u,photoPathSm:s}},D=()=>{const o=n.useRef({}).current;return n.useEffect(()=>{const e=document.createElement("div");return e.style.position="absolute",e.style.pointerEvents="none",e.style.top="0",e.style.width="100%",e.style.height="100%",o.elt=e,document.body.appendChild(e),()=>{document.body.removeChild(e)}},[o]),e=>(r,...u)=>{const s=e(r,...u);return r.draggableProps.style.position==="fixed"?S.createPortal(s,o.elt):s}};exports.useEmployeePhotoPath=M;exports.useRenderDraggableInPortal=D;exports.useSearchQuery=b;exports.useSearchQueryState=y;
|
package/dist/utils.cjs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./nivo-bar.es-BRHkg8Ew.cjs");require("react");require("@azure/msal-browser");require("@azure/msal-react");require("react-router-dom");require("react-dom");require("react-hook-form");require("react-flexmonster");const f=require("./numberUtils-BY7ziQF8.cjs"),g=({cell:{value:t}})=>e.jsxRuntimeExports.jsx(e.SimpleTooltip,{text:t,placement:"bottom",children:e.jsxRuntimeExports.jsx("div",{className:"w-100 text-truncate",children:t})}),h=({cell:{value:t}})=>e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:t==null?void 0:t.toLocaleString("cs-CZ")}),d=({cell:{value:t}})=>{const i=e.format(new Date(t),"dd.MM.yyyy");return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:t?i:""})},S=(t,i)=>{let n=!1,a=t;t[0]==="#"&&(a=t.slice(1),n=!0);let r=parseInt(a.substring(0,2),16),s=parseInt(a.substring(2,4),16),o=parseInt(a.substring(4,6),16);r+=i,s+=i,o+=i,r>255?r=255:r<0&&(r=0),s>255?s=255:s<0&&(s=0),o>255?o=255:o<0&&(o=0);const c=r.toString(16).length===1?"0"+r.toString(16):r.toString(16),m=s.toString(16).length===1?"0"+s.toString(16):s.toString(16),u=o.toString(16).length===1?"0"+o.toString(16):o.toString(16);return(n?"#":"")+c+m+u},p=t=>{const i=t.slice(3),n=[];for(let r=0;r<i.length;r+=2)n.push(i.slice(r,r+2));return`#${n.reverse().join("")}`};function l(t,i){t.setValue(i,null)}function D(t,i){i.forEach(n=>{l(t,n)})}const x=["edit","delete","info","warning","check","check-simple","add","cancel","cancel-simple","danger","chevron-left","chevron-right","chevron-up","chevron-down","chevron-double-left","chevron-double-right","folder","folder-filled","file-download","file-upload","star-outline","save","link","pending"];exports.atobUtf8=e.atobUtf8;exports.buildEmployeeNameString=e.buildEmployeeNameString;exports.buildOrgUnitString=e.buildOrgUnitString;exports.buildVehicleNameString=e.buildVehicleNameString;exports.capitalizeFirstLetter=e.capitalizeFirstLetter;exports.compareDate=e.compareDate;exports.compareDateTime=e.compareDateTime;exports.extractErrorsFromResponse=e.extractErrorsFromResponse;exports.extractFilename=e.extractFilename;exports.extractPermissionsFromResponse=e.extractPermissionsFromResponse;exports.fixNameIdNulls=e.fixNameIdNulls;exports.formatDate=e.formatDate;exports.formatDateTime=e.formatDateTime;exports.formatFileSize=e.formatFileSize;exports.getDateString=e.getDateString;exports.getDaysDifference=e.getDaysDifference;exports.getFirstDayOfMonth=e.getFirstDayOfMonth;exports.getFirstDayOfOffsetMonth=e.getFirstDayOfOffsetMonth;exports.getFirstDayOfYear=e.getFirstDayOfYear;exports.getLastDayOfMonth=e.getLastDayOfMonth;exports.getLastDayOfOffsetMonth=e.getLastDayOfOffsetMonth;exports.getLastDayOfYear=e.getLastDayOfYear;exports.hasOnlyNullValues=e.hasOnlyNullValues;exports.hookFormSetServerErrors=e.hookFormSetServerErrors;exports.isISODate=e.isISODate;exports.isPrimitive=e.isPrimitive;exports.isValidDate=e.isValidDate;exports.joinStrings=e.joinStrings;exports.msToStartOfNextDay=e.msToStartOfNextDay;exports.replaceNullValuesOnlyObjectsWithNulls=e.replaceNullValuesOnlyObjectsWithNulls;exports.saveFile=e.saveFile;exports.saveFileFromResponse=e.saveFileFromResponse;exports.shortenText=e.shortenText;exports.stringContains=e.stringContains;exports.stringSearchWithin=e.stringSearchWithin;exports.stringStartsWith=e.stringStartsWith;exports.trimIsoDate=e.trimIsoDate;exports.truncateText=e.truncateText;exports.urlfyArray=e.urlfyArray;exports.limitNumber=f.limitNumber;exports.CommonLuminusIconsArray=x;exports.adjustBrightness=S;exports.dateValueFormat=d;exports.hookFormSetNull=l;exports.hookFormSetNulls=D;exports.numFormat=h;exports.valueTooltip=g;exports.vclToHex=p;
|
package/dist/utils.es.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { j as i, aA as f, X as g } from "./
|
|
2
|
-
import {
|
|
1
|
+
import { j as i, aA as f, X as g } from "./nivo-bar.es-wC2Yrmiv.js";
|
|
2
|
+
import { c8 as M, c6 as V, c7 as k, c5 as w, c4 as L, bP as E, bQ as P, bd as B, bX as W, bM as A, b_ as G, bi as U, c3 as Y, ca as z, bW as X, bR as Z, b6 as $, bT as H, b7 as Q, bS as _, bU as q, bV as J, b$ as K, br as tt, bN as et, bZ as st, bO as rt, cb as at, bF as ot, c0 as it, bY as nt, bc as lt, cd as ct, c1 as mt, af as ft, c2 as gt, b5 as bt, c9 as ut, cc as dt } from "./nivo-bar.es-wC2Yrmiv.js";
|
|
3
3
|
import "react";
|
|
4
4
|
import "@azure/msal-browser";
|
|
5
5
|
import "@azure/msal-react";
|
|
@@ -8,7 +8,7 @@ import "react-dom";
|
|
|
8
8
|
import "react-hook-form";
|
|
9
9
|
import "react-flexmonster";
|
|
10
10
|
import { l as pt } from "./numberUtils-Bwf8nio8.js";
|
|
11
|
-
const
|
|
11
|
+
const D = ({ cell: { value: t } }) => /* @__PURE__ */ i.jsx(f, { text: t, placement: "bottom", children: /* @__PURE__ */ i.jsx("div", { className: "w-100 text-truncate", children: t }) }), O = ({ cell: { value: t } }) => /* @__PURE__ */ i.jsx(i.Fragment, { children: t == null ? void 0 : t.toLocaleString("cs-CZ") }), N = ({ cell: { value: t } }) => {
|
|
12
12
|
const s = g(new Date(t), "dd.MM.yyyy");
|
|
13
13
|
return /* @__PURE__ */ i.jsx(i.Fragment, { children: t ? s : "" });
|
|
14
14
|
}, j = (t, s) => {
|
|
@@ -24,12 +24,12 @@ const F = ({ cell: { value: t } }) => /* @__PURE__ */ i.jsx(f, { text: t, placem
|
|
|
24
24
|
o.push(s.slice(e, e + 2));
|
|
25
25
|
return `#${o.reverse().join("")}`;
|
|
26
26
|
};
|
|
27
|
-
function
|
|
27
|
+
function b(t, s) {
|
|
28
28
|
t.setValue(s, null);
|
|
29
29
|
}
|
|
30
30
|
function T(t, s) {
|
|
31
31
|
s.forEach((o) => {
|
|
32
|
-
|
|
32
|
+
b(t, o);
|
|
33
33
|
});
|
|
34
34
|
}
|
|
35
35
|
const R = [
|
|
@@ -61,15 +61,15 @@ const R = [
|
|
|
61
61
|
export {
|
|
62
62
|
R as CommonLuminusIconsArray,
|
|
63
63
|
j as adjustBrightness,
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
64
|
+
M as atobUtf8,
|
|
65
|
+
V as buildEmployeeNameString,
|
|
66
|
+
k as buildOrgUnitString,
|
|
67
|
+
w as buildVehicleNameString,
|
|
68
|
+
L as capitalizeFirstLetter,
|
|
69
69
|
E as compareDate,
|
|
70
|
-
|
|
70
|
+
P as compareDateTime,
|
|
71
71
|
N as dateValueFormat,
|
|
72
|
-
|
|
72
|
+
B as extractErrorsFromResponse,
|
|
73
73
|
W as extractFilename,
|
|
74
74
|
A as extractPermissionsFromResponse,
|
|
75
75
|
G as fixNameIdNulls,
|
|
@@ -80,12 +80,12 @@ export {
|
|
|
80
80
|
Z as getDaysDifference,
|
|
81
81
|
$ as getFirstDayOfMonth,
|
|
82
82
|
H as getFirstDayOfOffsetMonth,
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
83
|
+
Q as getFirstDayOfYear,
|
|
84
|
+
_ as getLastDayOfMonth,
|
|
85
|
+
q as getLastDayOfOffsetMonth,
|
|
86
|
+
J as getLastDayOfYear,
|
|
87
87
|
K as hasOnlyNullValues,
|
|
88
|
-
|
|
88
|
+
b as hookFormSetNull,
|
|
89
89
|
T as hookFormSetNulls,
|
|
90
90
|
tt as hookFormSetServerErrors,
|
|
91
91
|
et as isISODate,
|
|
@@ -102,9 +102,9 @@ export {
|
|
|
102
102
|
mt as stringContains,
|
|
103
103
|
ft as stringSearchWithin,
|
|
104
104
|
gt as stringStartsWith,
|
|
105
|
-
|
|
106
|
-
|
|
105
|
+
bt as trimIsoDate,
|
|
106
|
+
ut as truncateText,
|
|
107
107
|
dt as urlfyArray,
|
|
108
|
-
|
|
108
|
+
D as valueTooltip,
|
|
109
109
|
v as vclToHex
|
|
110
110
|
};
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";const s=require("./main.es-BabJ-geZ.cjs"),i="_loading_obchl_1",r="_spinner-grow_obchl_10",l="_second_obchl_14",t="_third_obchl_17",a="_loadingBlock_obchl_21",c="_sizeLine_obchl_29",d="_sizeFill_obchl_36",o={loading:i,"spinner-grow":"_spinner-grow_obchl_10",spinnerGrow:r,second:l,third:t,loadingBlock:a,sizeLine:c,sizeFill:d},_=()=>s.jsxRuntimeExports.jsxs("div",{className:s.classNames("luminus-loading",o.loading),children:[s.jsxRuntimeExports.jsx("div",{className:s.classNames("spinner-grow",o.spinnerGrow,"text-primary"),role:"status"}),s.jsxRuntimeExports.jsx("div",{className:s.classNames("spinner-grow",o.spinnerGrow,"text-primary",o.second),role:"status"}),s.jsxRuntimeExports.jsx("div",{className:s.classNames("spinner-grow",o.spinnerGrow,"text-primary",o.third),role:"status"})]}),m=({children:n,disabled:e})=>s.jsxRuntimeExports.jsx(s.FormDisabledContext.Provider,{value:e,children:n});exports.FormDisabledProvider=m;exports.Loading=_;exports.classes=o;
|