@mmb-digital/ds-lilly 0.10.10 → 0.10.12

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/ds-lilly.js CHANGED
@@ -107950,7 +107950,7 @@ function es_reducer(state, action) {
107950
107950
 
107951
107951
 
107952
107952
  var FileList = function (_a) {
107953
- var files = _a.files, handleOnDelete = _a.handleOnDelete, _b = _a.hideImagePreview, hideImagePreview = _b === void 0 ? false : _b, _c = _a.messages, ariaForDelete = _c.ariaForDelete, errorMessages = _c.multipleUploaderErrors, onShow = _a.onShow, _d = _a.selectMultiple, selectMultiple = _d === void 0 ? false : _d, uploadProgress = _a.uploadProgress, _e = _a.withProgressBar, withProgressBar = _e === void 0 ? false : _e;
107953
+ var disableRemovalOfUploaded = _a.disableRemovalOfUploaded, files = _a.files, handleOnDelete = _a.handleOnDelete, _b = _a.hideImagePreview, hideImagePreview = _b === void 0 ? false : _b, _c = _a.messages, ariaForDelete = _c.ariaForDelete, errorMessages = _c.multipleUploaderErrors, onShow = _a.onShow, _d = _a.selectMultiple, selectMultiple = _d === void 0 ? false : _d, _e = _a.uploadedFiles, uploadedFiles = _e === void 0 ? [] : _e, uploadProgress = _a.uploadProgress, _f = _a.withProgressBar, withProgressBar = _f === void 0 ? false : _f;
107954
107954
  var handleOnShow = function (id) { return function () { return onShow && onShow(id); }; };
107955
107955
  var handleOnDeleteAction = function (id) { return function () { return handleOnDelete && handleOnDelete(id); }; };
107956
107956
  var renderImage = function (file) {
@@ -107991,13 +107991,14 @@ var FileList = function (_a) {
107991
107991
  iconName = 'documents';
107992
107992
  }
107993
107993
  }
107994
+ var isUploaded = !uploading && uploadedFiles.some(function (uploadedFile) { return uploadedFile.id === file.id; });
107994
107995
  return (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(IconListItem, { key: file.id, iconBackgroundColor: hasErrors ? 'redNormal' : undefined, iconName: iconName },
107995
107996
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_["Fragment"], null,
107996
107997
  hasErrors && (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement("div", { className: classBinder_cx('f-fileUpload__errorTitle') },
107997
107998
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement("strong", null, file.name + " " + (errorMessages === null || errorMessages === void 0 ? void 0 : errorMessages.didNotUpload)))),
107998
107999
  !hasErrors && (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_["Fragment"], null,
107999
108000
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(Button, { isSmall: true, "aria-hidden": "true", ariaLabel: "", theme: 'f-fileUpload__fileName', type: "transparent", onClick: handleOnShow(file.id) }, file.name),
108000
- external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(Button, { ariaLabel: ariaForDelete + " " + file.name, color: "red", onlyIconName: uploading ? 'close' : 'bin', type: "transparent", onClick: function () { return handleOnDelete(file.id); } }))),
108001
+ !(isUploaded && disableRemovalOfUploaded) && (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(Button, { ariaLabel: ariaForDelete + " " + file.name, color: "red", onlyIconName: uploading ? 'close' : 'bin', type: "transparent", onClick: function () { return handleOnDelete(file.id); } })))),
108001
108002
  hasErrors &&
108002
108003
  ((_c = file === null || file === void 0 ? void 0 : file.errors) === null || _c === void 0 ? void 0 : _c.map(function (error, index) { return (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement("div", { key: index, className: classBinder_cx('f-fileUpload__errorDesc') },
108003
108004
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(Text, { component: "div", size: "xSmall", type: "secondary" }, errorMessages &&
@@ -108078,7 +108079,7 @@ var FileUpload_spreadArray = (undefined && undefined.__spreadArray) || function
108078
108079
 
108079
108080
 
108080
108081
  var FileUpload_FileUpload = function (_a) {
108081
- var accept = _a.accept, _b = _a.fileLimit, fileLimit = _b === void 0 ? 1 : _b, files = _a.files, _c = _a.hideImagePreview, hideImagePreview = _c === void 0 ? false : _c, _d = _a.hideTitle, hideTitle = _d === void 0 ? false : _d, maxSizeBytes = _a.maxSizeBytes, messages = _a.messages, minSizeBytes = _a.minSizeBytes, onDelete = _a.onDelete, onError = _a.onError, onSelectFile = _a.onSelectFile, onShow = _a.onShow, _e = _a.selectMultiple, selectMultiple = _e === void 0 ? false : _e, setFiles = _a.setFiles, theme = _a.theme, uploadProgress = _a.uploadProgress, _f = _a.withProgressBar, withProgressBar = _f === void 0 ? false : _f;
108082
+ var accept = _a.accept, disableRemovalOfUploaded = _a.disableRemovalOfUploaded, _b = _a.fileLimit, fileLimit = _b === void 0 ? 1 : _b, files = _a.files, _c = _a.hideImagePreview, hideImagePreview = _c === void 0 ? false : _c, _d = _a.hideTitle, hideTitle = _d === void 0 ? false : _d, maxSizeBytes = _a.maxSizeBytes, messages = _a.messages, minSizeBytes = _a.minSizeBytes, onDelete = _a.onDelete, onError = _a.onError, onSelectFile = _a.onSelectFile, onShow = _a.onShow, _e = _a.selectMultiple, selectMultiple = _e === void 0 ? false : _e, setFiles = _a.setFiles, theme = _a.theme, uploadProgress = _a.uploadProgress, uploadedFiles = _a.uploadedFiles, _f = _a.withProgressBar, withProgressBar = _f === void 0 ? false : _f;
108082
108083
  var _g = useDropzone({
108083
108084
  getFilesFromEvent: function (event) { return applyFileLimit(event); },
108084
108085
  onDropRejected: function (files) {
@@ -108171,7 +108172,7 @@ var FileUpload_FileUpload = function (_a) {
108171
108172
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement("div", { className: classBinder_cx('f-fileUpload__dropZone') },
108172
108173
  external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(Icon, { backgroundColor: "cloudNormal", name: isUploadInProgress ? 'loading' : 'upload', size: "xLarge", theme: "f-fileUpload__uploadIcon" }),
108173
108174
  getTitle()))),
108174
- external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(FileList, { files: files, handleOnDelete: handleOnDelete, hideImagePreview: hideImagePreview, messages: messages, selectMultiple: selectMultiple, uploadProgress: uploadProgress, withProgressBar: withProgressBar, onShow: onShow })));
108175
+ external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(FileList, { disableRemovalOfUploaded: disableRemovalOfUploaded, files: files, handleOnDelete: handleOnDelete, hideImagePreview: hideImagePreview, messages: messages, selectMultiple: selectMultiple, uploadProgress: uploadProgress, uploadedFiles: uploadedFiles, withProgressBar: withProgressBar, onShow: onShow })));
108175
108176
  };
108176
108177
 
108177
108178
  // CONCATENATED MODULE: ./src/components/Form/FileUpload/FileUpload.hook.tsx
@@ -108189,14 +108190,22 @@ var FileUpload_hook_assign = (undefined && undefined.__assign) || function () {
108189
108190
  /* eslint-disable @typescript-eslint/ban-ts-comment */
108190
108191
 
108191
108192
 
108192
- var useFileUpload = function (initialFiles) {
108193
+ var useFileUpload = function (initialFiles, initialUploadedFiles) {
108193
108194
  var _a = Object(external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_["useState"])(initialFiles || []), files = _a[0], setFiles = _a[1];
108195
+ var _b = Object(external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_["useState"])(initialUploadedFiles || []), uploadedFiles = _b[0], setUploadedFiles = _b[1];
108194
108196
  var handleClearFiles = function () { return setFiles([]); };
108195
- var FileUpload = function (props) { return (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(FileUpload_FileUpload, FileUpload_hook_assign({}, props, { files: files, setFiles: setFiles }))); };
108197
+ var FileUpload = function (props) { return (external_root_React_commonjs2_react_commonjs_react_amd_react_umd_react_default.a.createElement(FileUpload_FileUpload, FileUpload_hook_assign({}, props, { files: files, setFiles: setFiles, uploadedFiles: uploadedFiles }))); };
108198
+ var markFileAsUploaded = function (file) {
108199
+ setUploadedFiles(function (prev) { return prev.filter(function (_a) {
108200
+ var id = _a.id;
108201
+ return id !== file.id;
108202
+ }).concat(file); });
108203
+ };
108196
108204
  return {
108197
108205
  FileUpload: FileUpload,
108198
108206
  files: files,
108199
- handleClearFiles: handleClearFiles
108207
+ handleClearFiles: handleClearFiles,
108208
+ markFileAsUploaded: markFileAsUploaded
108200
108209
  };
108201
108210
  };
108202
108211
 
@@ -6,6 +6,8 @@ export interface FileUploadPropsType extends ComponentPropsType {
6
6
  accept?: string | string[];
7
7
  /** @ignore Inner component state with all files. 💀 It`s provided if you use hook. 💀*/
8
8
  files: FileListPropsType['files'];
9
+ /** @ignore Inner component state with all files. 💀 It`s provided if you use hook. 💀*/
10
+ uploadedFiles: FileListPropsType['files'];
9
11
  /** Define maximum uploadable files. */
10
12
  fileLimit?: number;
11
13
  /** Hides preview for the chosen file if it's an image. */
@@ -54,6 +56,8 @@ export interface FileUploadPropsType extends ComponentPropsType {
54
56
  uploadProgress?: FileListPropsType['uploadProgress'];
55
57
  /** Display or hide file upload progress bar, even for single file */
56
58
  withProgressBar?: FileListPropsType['withProgressBar'];
59
+ /** Disable remove button for uploaded files */
60
+ disableRemovalOfUploaded?: boolean;
57
61
  }
58
62
  export interface FileError {
59
63
  message: string;
@@ -71,5 +75,5 @@ export declare type FileType = {
71
75
  /** List of all errors */
72
76
  errors?: FileError[];
73
77
  };
74
- export declare const FileUpload: ({ accept, fileLimit, files, hideImagePreview, hideTitle, maxSizeBytes, messages, minSizeBytes, onDelete, onError, onSelectFile, onShow, selectMultiple, setFiles, theme, uploadProgress, withProgressBar }: FileUploadPropsType) => JSX.Element;
78
+ export declare const FileUpload: ({ accept, disableRemovalOfUploaded, fileLimit, files, hideImagePreview, hideTitle, maxSizeBytes, messages, minSizeBytes, onDelete, onError, onSelectFile, onShow, selectMultiple, setFiles, theme, uploadProgress, uploadedFiles, withProgressBar }: FileUploadPropsType) => JSX.Element;
75
79
  //# sourceMappingURL=FileUpload.d.ts.map
@@ -3,6 +3,7 @@ export interface FileUploadHookType {
3
3
  FileUpload: ({ accept, maxSizeBytes, messages, minSizeBytes, onDelete, onError, onSelectFile, onShow, selectMultiple, theme, uploadProgress }: Omit<FileUploadPropsType, 'files' | 'setFiles'>) => JSX.Element;
4
4
  files: FileType[];
5
5
  handleClearFiles: () => void;
6
+ markFileAsUploaded: (file: FileType) => void;
6
7
  }
7
- export declare const useFileUpload: (initialFiles: FileType[]) => FileUploadHookType;
8
+ export declare const useFileUpload: (initialFiles: FileType[], initialUploadedFiles?: FileType[] | undefined) => FileUploadHookType;
8
9
  //# sourceMappingURL=FileUpload.hook.d.ts.map
@@ -14,8 +14,10 @@ export interface FileListPropsType {
14
14
  };
15
15
  onShow?: (id: string) => void;
16
16
  selectMultiple?: boolean;
17
+ uploadedFiles?: FileType[];
17
18
  uploadProgress?: Record<string, number>;
18
19
  withProgressBar?: boolean;
20
+ disableRemovalOfUploaded?: boolean;
19
21
  }
20
- export declare const FileList: ({ files, handleOnDelete, hideImagePreview, messages: { ariaForDelete, multipleUploaderErrors: errorMessages }, onShow, selectMultiple, uploadProgress, withProgressBar }: FileListPropsType) => JSX.Element;
22
+ export declare const FileList: ({ disableRemovalOfUploaded, files, handleOnDelete, hideImagePreview, messages: { ariaForDelete, multipleUploaderErrors: errorMessages }, onShow, selectMultiple, uploadedFiles, uploadProgress, withProgressBar }: FileListPropsType) => JSX.Element;
21
23
  //# sourceMappingURL=FileList.d.ts.map
package/package.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "@mmb-digital/ds-lilly",
3
- "version": "0.10.10",
3
+ "version": "0.10.12",
4
4
  "description": "MMB LILLY design system",
5
5
  "license": "UNLICENSED",
6
6
  "sideEffects": false,
7
7
  "main": "dist/ds-lilly.js",
8
- "module": "dist/",
8
+ "module": "dist/ds-lilly.js",
9
9
  "source": "src/index.ts",
10
10
  "types": "dist/types/src/index.d.ts",
11
11
  "files": [