@js-empire/emperor-ui 1.3.5 → 1.3.6

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.
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import { d as a } from "./index-ABKcY4tX.js";
3
+ var t = a;
4
+ export {
5
+ t as default
6
+ };
@@ -1,5 +1,6 @@
1
- import { l as a, a as s, d as e } from "./index-BwRbIPvN.js";
2
- import { A as n, b as c, D as l, c as d, e as m, F as u, f as b, H as p, g, J as x, K as V, L as f, h as T, M as y, i as D, j as A, k as S, m as v, N as P, n as E, o as M, P as h, p as C, q as B, S as O, r as I, s as G, V as L, t as N, u as R, v as F, w as k, x as j, y as w, z, B as q, C as K, E as H, G as W, I as U, O as Z, Q as J, R as Q, T as X, U as Y, W as _, X as $, Y as aa, Z as sa, _ as ea, $ as ia, a0 as ta, a1 as oa, a2 as ra, a3 as na, a4 as ca, a5 as la, a6 as da, a7 as ma, a8 as ua, a9 as ba, aa as pa, ab as ga, ac as xa, ad as Va, ae as fa, af as Ta, ag as ya, ah as Da, ai as Aa, aj as Sa, ak as va, al as Pa, am as Ea, an as Ma, ao as ha, ap as Ca, aq as Ba, ar as Oa, as as Ia, at as Ga, au as La, av as Na, aw as Ra, ax as Fa, ay as ka, az as ja, aA as wa, aB as za, aC as qa, aD as Ka, aE as Ha, aF as Wa, aG as Ua, aH as Za, aI as Ja, aJ as Qa, aK as Xa, aL as Ya, aM as _a, aN as $a, aO as as, aP as ss, aQ as es, aR as is, aS as ts, aT as os, aU as rs, aV as ns, aW as cs, aX as ls, aY as ds, aZ as ms, a_ as us, a$ as bs, b0 as ps, b1 as gs, b2 as xs, b3 as Vs, b4 as fs, b5 as Ts, b6 as ys, b7 as Ds, b8 as As, b9 as Ss, ba as vs, bb as Ps, bc as Es, bd as Ms, be as hs, bf as Cs, bg as Bs, bh as Os, bi as Is, bj as Gs, bk as Ls, bl as Ns, bm as Rs, bn as Fs, bo as ks, bp as js, bq as ws, br as zs, bs as qs, bt as Ks, bu as Hs, bv as Ws, bw as Us, bx as Zs, by as Js, bz as Qs, bA as Xs, bB as Ys, bC as _s, bD as $s, bE as ae, bF as se, bG as ee, bH as ie, bI as te, bJ as oe, bK as re, bL as ne, bM as ce, bN as le, bO as de, bP as me, bQ as ue, bR as be, bS as pe, bT as ge, bU as xe, bV as Ve, bW as fe, bX as Te, bY as ye, bZ as De, b_ as Ae, b$ as Se, c0 as ve, c1 as Pe, c2 as Ee, c3 as Me, c4 as he, c5 as Ce, c6 as Be, c7 as Oe, c8 as Ie, c9 as Ge, ca as Le, cb as Ne, cc as Re, cd as Fe, ce as ke, cf as je, cg as we, ch as ze, ci as qe, cj as Ke, ck as He, cl as We, cm as Ue, cn as Ze, co as Je, cp as Qe, cq as Xe, cr as Ye, cs as _e, ct as $e, cu as ai, cv as si, cw as ei, cx as ii, cy as ti, cz as oi, cA as ri, cB as ni, cC as ci, cD as li, cE as di, cF as mi, cG as ui, cH as bi, cI as pi, cJ as gi, cK as xi, cL as Vi, cM as fi, cN as Ti, cO as yi, cP as Di, cQ as Ai, cR as Si, cS as vi, cT as Pi, cU as Ei, cV as Mi, cW as hi, cX as Ci, cY as Bi, cZ as Oi, c_ as Ii, c$ as Gi, d0 as Li, d1 as Ni, d2 as Ri, d3 as Fi, d4 as ki, d5 as ji, d6 as wi, d7 as zi, d8 as qi, d9 as Ki, da as Hi, db as Wi, dc as Ui, dd as Zi, de as Ji, df as Qi, dg as Xi, dh as Yi, di as _i, dj as $i, dk as at, dl as st, dm as et, dn as it, dp as tt, dq as ot, dr as rt, ds as nt, dt as ct, du as lt, dv as dt, dw as mt, dx as ut, dy as bt, dz as pt, dA as gt } from "./index-BwRbIPvN.js";
1
+ "use client";
2
+ import { l as a, a as s, d as e } from "./index-ABKcY4tX.js";
3
+ import { A as n, b as c, D as l, c as d, e as m, F as u, f as b, H as p, g, J as x, K as V, L as f, h as T, M as y, i as D, j as A, k as S, m as v, N as P, n as E, o as M, P as h, p as C, q as B, S as O, r as I, s as G, V as L, t as N, u as R, v as F, w as k, x as j, y as w, z, B as q, C as K, E as H, G as W, I as U, O as Z, Q as J, R as Q, T as X, U as Y, W as _, X as $, Y as aa, Z as sa, _ as ea, $ as ia, a0 as ta, a1 as oa, a2 as ra, a3 as na, a4 as ca, a5 as la, a6 as da, a7 as ma, a8 as ua, a9 as ba, aa as pa, ab as ga, ac as xa, ad as Va, ae as fa, af as Ta, ag as ya, ah as Da, ai as Aa, aj as Sa, ak as va, al as Pa, am as Ea, an as Ma, ao as ha, ap as Ca, aq as Ba, ar as Oa, as as Ia, at as Ga, au as La, av as Na, aw as Ra, ax as Fa, ay as ka, az as ja, aA as wa, aB as za, aC as qa, aD as Ka, aE as Ha, aF as Wa, aG as Ua, aH as Za, aI as Ja, aJ as Qa, aK as Xa, aL as Ya, aM as _a, aN as $a, aO as as, aP as ss, aQ as es, aR as is, aS as ts, aT as os, aU as rs, aV as ns, aW as cs, aX as ls, aY as ds, aZ as ms, a_ as us, a$ as bs, b0 as ps, b1 as gs, b2 as xs, b3 as Vs, b4 as fs, b5 as Ts, b6 as ys, b7 as Ds, b8 as As, b9 as Ss, ba as vs, bb as Ps, bc as Es, bd as Ms, be as hs, bf as Cs, bg as Bs, bh as Os, bi as Is, bj as Gs, bk as Ls, bl as Ns, bm as Rs, bn as Fs, bo as ks, bp as js, bq as ws, br as zs, bs as qs, bt as Ks, bu as Hs, bv as Ws, bw as Us, bx as Zs, by as Js, bz as Qs, bA as Xs, bB as Ys, bC as _s, bD as $s, bE as ae, bF as se, bG as ee, bH as ie, bI as te, bJ as oe, bK as re, bL as ne, bM as ce, bN as le, bO as de, bP as me, bQ as ue, bR as be, bS as pe, bT as ge, bU as xe, bV as Ve, bW as fe, bX as Te, bY as ye, bZ as De, b_ as Ae, b$ as Se, c0 as ve, c1 as Pe, c2 as Ee, c3 as Me, c4 as he, c5 as Ce, c6 as Be, c7 as Oe, c8 as Ie, c9 as Ge, ca as Le, cb as Ne, cc as Re, cd as Fe, ce as ke, cf as je, cg as we, ch as ze, ci as qe, cj as Ke, ck as He, cl as We, cm as Ue, cn as Ze, co as Je, cp as Qe, cq as Xe, cr as Ye, cs as _e, ct as $e, cu as ai, cv as si, cw as ei, cx as ii, cy as ti, cz as oi, cA as ri, cB as ni, cC as ci, cD as li, cE as di, cF as mi, cG as ui, cH as bi, cI as pi, cJ as gi, cK as xi, cL as Vi, cM as fi, cN as Ti, cO as yi, cP as Di, cQ as Ai, cR as Si, cS as vi, cT as Pi, cU as Ei, cV as Mi, cW as hi, cX as Ci, cY as Bi, cZ as Oi, c_ as Ii, c$ as Gi, d0 as Li, d1 as Ni, d2 as Ri, d3 as Fi, d4 as ki, d5 as ji, d6 as wi, d7 as zi, d8 as qi, d9 as Ki, da as Hi, db as Wi, dc as Ui, dd as Zi, de as Ji, df as Qi, dg as Xi, dh as Yi, di as _i, dj as $i, dk as at, dl as st, dm as et, dn as it, dp as tt, dq as ot, dr as rt, ds as nt, dt as ct, du as lt, dv as dt, dw as mt, dx as ut, dy as bt, dz as pt, dA as gt } from "./index-ABKcY4tX.js";
3
4
  const t = {
4
5
  ...e,
5
6
  ...s,
package/dist/index.d.ts CHANGED
@@ -60,6 +60,8 @@ export declare const ALLOWED_IMAGES_TYPES: string[];
60
60
 
61
61
  export declare const ALLOWED_PDF_TYPES: string[];
62
62
 
63
+ export declare const ALLOWED_SHEET_TYPES: string[];
64
+
63
65
  export declare type AppDirection = "ltr" | "rtl";
64
66
 
65
67
  declare const ar: {
@@ -1224,6 +1226,7 @@ export declare type UploaderContextState = {
1224
1226
  fileTypes: FileType[];
1225
1227
  onInputChange: SharedOnInputChangeType;
1226
1228
  handleClearFile: (fileName?: string) => void;
1229
+ setFiles?: Dispatch<SetStateAction<FileObject[]>>;
1227
1230
  modal?: Omit<ModalProps, "children"> & {
1228
1231
  onOpen?: () => void;
1229
1232
  };
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import { d as a } from "./index-ABKcY4tX.js";
3
+ var e = a;
4
+ export {
5
+ e as default
6
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@js-empire/emperor-ui",
3
3
  "description": "They provide the atoms, we provide the empire.",
4
- "version": "1.3.5",
4
+ "version": "1.3.6",
5
5
  "author": "JS Empire - Mustafa Alhasanat",
6
6
  "license": "ISC",
7
7
  "type": "module",
@@ -36,11 +36,42 @@ export const Uploader = forwardRef<
36
36
  HTMLDivElement,
37
37
  ComponentProps<"div"> & VariantProps<typeof uploaderStyles> & UploaderProps
38
38
  >(({ className, ...props }, ref) => {
39
- const { isAvatar, hideListing, isFileViewable, hideErrorMessage } = props;
39
+ const {
40
+ isAvatar,
41
+ hideListing,
42
+ isFileViewable,
43
+ hideErrorMessage,
44
+ // Uploader API — must not be forwarded to a DOM element (React warns on unknown props).
45
+ selectedFile,
46
+ setSelectedFile,
47
+ labelId,
48
+ labelContent,
49
+ avatarLabelContent,
50
+ title,
51
+ errorMessage,
52
+ isRequired,
53
+ isDraggable,
54
+ isLoading,
55
+ isMulti,
56
+ placeholderImage,
57
+ files,
58
+ fileTypes,
59
+ onInputChange,
60
+ handleClearFile,
61
+ modal,
62
+ classNames,
63
+ locales,
64
+ setFiles,
65
+ ...divProps
66
+ } = props;
40
67
 
41
68
  return (
42
69
  <UploaderProvider {...props}>
43
- <div ref={ref} className={cn(uploaderStyles({ className }))} {...props}>
70
+ <div
71
+ ref={ref}
72
+ className={cn(uploaderStyles({ className }))}
73
+ {...divProps}
74
+ >
44
75
  <UploaderTitle />
45
76
 
46
77
  {isAvatar ? <AvatarLabel /> : <UploadFileLabel />}
@@ -30,8 +30,9 @@ export const Default: Story = {
30
30
  args: {},
31
31
  render: () => {
32
32
  const uploadProps = useUploader({
33
- fileTypes: ["image", "pdf"],
33
+ fileTypes: ["sheet"],
34
34
  labelId: "image",
35
+ isMulti: true,
35
36
  });
36
37
 
37
38
  return <Uploader {...uploadProps} />;
@@ -16,6 +16,12 @@ export const ALLOWED_DOC_TYPES = [
16
16
  "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
17
17
  ];
18
18
 
19
+ export const ALLOWED_SHEET_TYPES = [
20
+ "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
21
+ "application/vnd.ms-excel",
22
+ "text/csv",
23
+ ];
24
+
19
25
  export const ONE_MEGABYTE = 1024;
20
26
 
21
27
  export const fileTypesMapping: { [key: string]: string[] } = {
@@ -23,5 +29,5 @@ export const fileTypesMapping: { [key: string]: string[] } = {
23
29
  doc: [".doc", ".docx"],
24
30
  pdf: [".pdf"],
25
31
  video: [".mp4"],
26
- sheet: [".xlsx", ".xlx"],
32
+ sheet: [".xlsx", ".xlx", ".xls", ".csv"],
27
33
  };
package/src/index.ts CHANGED
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import "./styles/globals.css";
2
4
 
3
5
  export * from "./components";
@@ -81,6 +81,7 @@ export type UploaderContextState = {
81
81
 
82
82
  onInputChange: SharedOnInputChangeType;
83
83
  handleClearFile: (fileName?: string) => void;
84
+ setFiles?: Dispatch<SetStateAction<FileObject[]>>;
84
85
 
85
86
  modal?: Omit<ModalProps, "children"> & {
86
87
  onOpen?: () => void;
@@ -3,6 +3,7 @@ import {
3
3
  ALLOWED_IMAGES_TYPES,
4
4
  ALLOWED_PDF_TYPES,
5
5
  ONE_MEGABYTE,
6
+ ALLOWED_SHEET_TYPES,
6
7
  } from "@/constants";
7
8
  import { FileObject, FileType } from "@/types";
8
9
  import { addToast } from "@heroui/toast";
@@ -15,6 +16,7 @@ export const mapFileType = (fileType: string): FileType | null => {
15
16
  if (ALLOWED_IMAGES_TYPES.includes(fileType)) return "image";
16
17
  if (ALLOWED_PDF_TYPES.includes(fileType)) return "pdf";
17
18
  if (ALLOWED_DOC_TYPES.includes(fileType)) return "doc";
19
+ if (ALLOWED_SHEET_TYPES.includes(fileType)) return "sheet";
18
20
 
19
21
  return null;
20
22
  };
@@ -27,6 +29,7 @@ export const getAllowedTypes = (fileTypes: FileType[]): string[] => {
27
29
  if (fileType === "image") allowedTypes.push(...ALLOWED_IMAGES_TYPES);
28
30
  if (fileType === "doc") allowedTypes.push(...ALLOWED_DOC_TYPES);
29
31
  if (fileType === "pdf") allowedTypes.push(...ALLOWED_PDF_TYPES);
32
+ if (fileType === "sheet") allowedTypes.push(...ALLOWED_SHEET_TYPES);
30
33
  });
31
34
 
32
35
  return allowedTypes;
package/vite.config.ts CHANGED
@@ -33,6 +33,9 @@ export default defineConfig({
33
33
  rollupOptions: {
34
34
  external: ["react", "react-dom"],
35
35
  output: {
36
+ // Next.js App Router: mark the package as client-only so the server bundle
37
+ // does not evaluate HeroUI / motion / aria code that touches `document`.
38
+ banner: '"use client";\n',
36
39
  globals: {
37
40
  react: "React",
38
41
  "react-dom": "ReactDOM",
@@ -1,5 +0,0 @@
1
- import { d as a } from "./index-BwRbIPvN.js";
2
- var o = a;
3
- export {
4
- o as default
5
- };
@@ -1,5 +0,0 @@
1
- import { d as a } from "./index-BwRbIPvN.js";
2
- var r = a;
3
- export {
4
- r as default
5
- };