@memori.ai/memori-react 5.1.0 → 6.0.0-rc.0
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/CHANGELOG.md +8 -0
- package/README.md +1 -0
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.d.ts +14 -0
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.js +66 -0
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.js.map +1 -0
- package/dist/components/Header/Header.css +2 -1
- package/dist/components/Header/Header.d.ts +2 -0
- package/dist/components/Header/Header.js +3 -2
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/ImageUpload/ImageUpload.css +168 -0
- package/dist/components/ImageUpload/ImageUpload.d.ts +28 -0
- package/dist/components/ImageUpload/ImageUpload.js +163 -0
- package/dist/components/ImageUpload/ImageUpload.js.map +1 -0
- package/dist/components/LoginDrawer/LoginDrawer.css +84 -0
- package/dist/components/LoginDrawer/LoginDrawer.d.ts +15 -0
- package/dist/components/LoginDrawer/LoginDrawer.js +129 -0
- package/dist/components/LoginDrawer/LoginDrawer.js.map +1 -0
- package/dist/components/MemoriWidget/MemoriWidget.d.ts +2 -1
- package/dist/components/MemoriWidget/MemoriWidget.js +33 -5
- package/dist/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/dist/components/StartPanel/StartPanel.d.ts +2 -0
- package/dist/components/StartPanel/StartPanel.js +2 -2
- package/dist/components/StartPanel/StartPanel.js.map +1 -1
- package/dist/components/layouts/Default.d.ts +17 -0
- package/dist/components/layouts/Default.js +8 -0
- package/dist/components/layouts/Default.js.map +1 -0
- package/dist/components/ui/Message.d.ts +17 -0
- package/dist/components/ui/Message.js +13 -0
- package/dist/components/ui/Message.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +3 -2
- package/dist/index.js.map +1 -1
- package/dist/locales/en.json +25 -0
- package/dist/locales/it.json +25 -0
- package/dist/styles.css +1 -0
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.d.ts +14 -0
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.js +63 -0
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.js.map +1 -0
- package/esm/components/Header/Header.css +2 -1
- package/esm/components/Header/Header.d.ts +2 -0
- package/esm/components/Header/Header.js +3 -2
- package/esm/components/Header/Header.js.map +1 -1
- package/esm/components/ImageUpload/ImageUpload.css +168 -0
- package/esm/components/ImageUpload/ImageUpload.d.ts +28 -0
- package/esm/components/ImageUpload/ImageUpload.js +160 -0
- package/esm/components/ImageUpload/ImageUpload.js.map +1 -0
- package/esm/components/LoginDrawer/LoginDrawer.css +84 -0
- package/esm/components/LoginDrawer/LoginDrawer.d.ts +15 -0
- package/esm/components/LoginDrawer/LoginDrawer.js +125 -0
- package/esm/components/LoginDrawer/LoginDrawer.js.map +1 -0
- package/esm/components/MemoriWidget/MemoriWidget.d.ts +2 -1
- package/esm/components/MemoriWidget/MemoriWidget.js +33 -5
- package/esm/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/esm/components/StartPanel/StartPanel.d.ts +2 -0
- package/esm/components/StartPanel/StartPanel.js +2 -2
- package/esm/components/StartPanel/StartPanel.js.map +1 -1
- package/esm/components/layouts/Default.d.ts +17 -0
- package/esm/components/layouts/Default.js +5 -0
- package/esm/components/layouts/Default.js.map +1 -0
- package/esm/components/ui/Message.d.ts +17 -0
- package/esm/components/ui/Message.js +10 -0
- package/esm/components/ui/Message.js.map +1 -0
- package/esm/index.d.ts +1 -0
- package/esm/index.js +3 -2
- package/esm/index.js.map +1 -1
- package/esm/locales/en.json +25 -0
- package/esm/locales/it.json +25 -0
- package/esm/styles.css +1 -0
- package/package.json +1 -1
- package/src/components/Header/Header.css +2 -1
- package/src/components/Header/Header.stories.tsx +27 -1
- package/src/components/Header/Header.test.tsx +14 -1
- package/src/components/Header/Header.tsx +17 -0
- package/src/components/Header/__snapshots__/Header.test.tsx.snap +260 -0
- package/src/components/LoginDrawer/LoginDrawer.css +84 -0
- package/src/components/LoginDrawer/LoginDrawer.stories.tsx +58 -0
- package/src/components/LoginDrawer/LoginDrawer.test.tsx +86 -0
- package/src/components/LoginDrawer/LoginDrawer.tsx +330 -0
- package/src/components/LoginDrawer/__snapshots__/LoginDrawer.test.tsx.snap +35 -0
- package/src/components/MemoriWidget/MemoriWidget.tsx +48 -4
- package/src/components/StartPanel/StartPanel.stories.tsx +3 -1
- package/src/components/StartPanel/StartPanel.test.tsx +12 -0
- package/src/components/StartPanel/StartPanel.tsx +11 -0
- package/src/components/StartPanel/__snapshots__/StartPanel.test.tsx.snap +7 -0
- package/src/components/layouts/__snapshots__/Chat.test.tsx.snap +20 -0
- package/src/components/layouts/__snapshots__/FullPage.test.tsx.snap +20 -0
- package/src/components/layouts/__snapshots__/Totem.test.tsx.snap +20 -0
- package/src/index.stories.tsx +0 -1
- package/src/index.tsx +4 -0
- package/src/locales/en.json +25 -0
- package/src/locales/it.json +25 -0
- package/src/mocks/data.ts +2 -2
- package/src/styles.css +1 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
|
|
2
2
|
|
|
3
|
+
## [6.0.0-rc.0](https://github.com/memori-ai/memori-react/compare/v5.1.0...v6.0.0-rc.0) (2024-03-14)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### Features
|
|
7
|
+
|
|
8
|
+
* add login ([cc8b88d](https://github.com/memori-ai/memori-react/commit/cc8b88d3f7a84c12c48eb45590f46f51314e15c8))
|
|
9
|
+
* preserve login token ([2765ec5](https://github.com/memori-ai/memori-react/commit/2765ec5f0d3b18ec9935847f3bb6147fd2cfcfa9))
|
|
10
|
+
|
|
3
11
|
## [5.1.0](https://github.com/memori-ai/memori-react/compare/v5.0.2...v5.1.0) (2024-03-11)
|
|
4
12
|
|
|
5
13
|
|
package/README.md
CHANGED
|
@@ -67,6 +67,7 @@ const App = () => (
|
|
|
67
67
|
| `showSettings` | | `bool` | `true` | Show the settings panel button |
|
|
68
68
|
| `showTypingText` | | `bool` | `false` | Show default sentences while loading text (see: Typing stories) |
|
|
69
69
|
| `showInstruct` | | `bool` | `false` | Show the switch selecting between test mode or instruct mode, needs an administrative session as a giver |
|
|
70
|
+
| `showLogin` | | `bool` | `true` | Show the login button |
|
|
70
71
|
| `showClear` | | `bool` | `false` | Show clear chat history button |
|
|
71
72
|
| `showOnlyLastMessages` | | `bool` | `true` or `false` \* | Show only last 2 messages. (\*) Defaults to `true` for `TOTEM` and `WEBSITE_ASSISTANT` layouts, `false` otherwise |
|
|
72
73
|
| `baseURL` | | `string` | | Base URL of the Memori, example: "https://aisuru.com" |
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Asset, ResponseSpec } from '@memori.ai/memori-api-client/dist/types';
|
|
2
|
+
export interface Props {
|
|
3
|
+
visible: boolean;
|
|
4
|
+
authToken: string;
|
|
5
|
+
sessionID: string;
|
|
6
|
+
tenantID: string;
|
|
7
|
+
uploadAssetURL: string;
|
|
8
|
+
deleteAsset: (token: string, assetURL: string) => Promise<ResponseSpec>;
|
|
9
|
+
onCancel?: () => void;
|
|
10
|
+
onOk: (asset: Asset) => Promise<void>;
|
|
11
|
+
apiURL?: string;
|
|
12
|
+
}
|
|
13
|
+
declare const AttachmentMediaModal: ({ visible, authToken, sessionID, tenantID, uploadAssetURL, deleteAsset, onCancel, onOk, apiURL, }: Props) => JSX.Element;
|
|
14
|
+
export default AttachmentMediaModal;
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const react_i18next_1 = require("react-i18next");
|
|
7
|
+
const error_1 = require("../../helpers/error");
|
|
8
|
+
const constants_1 = require("../../helpers/constants");
|
|
9
|
+
const media_1 = require("../../helpers/media");
|
|
10
|
+
const Modal_1 = tslib_1.__importDefault(require("../ui/Modal"));
|
|
11
|
+
const Message_1 = tslib_1.__importDefault(require("../ui/Message"));
|
|
12
|
+
const Button_1 = tslib_1.__importDefault(require("../ui/Button"));
|
|
13
|
+
const ImageUpload_1 = tslib_1.__importDefault(require("../ImageUpload/ImageUpload"));
|
|
14
|
+
const AttachmentMediaModal = ({ visible, authToken, sessionID, tenantID, uploadAssetURL, deleteAsset, onCancel, onOk, apiURL, }) => {
|
|
15
|
+
const { t } = (0, react_i18next_1.useTranslation)();
|
|
16
|
+
const [asset, setAsset] = (0, react_1.useState)();
|
|
17
|
+
return ((0, jsx_runtime_1.jsx)(Modal_1.default, { open: visible, title: t('media.addMediaLabel'), className: "attachment-media-modal", closable: true, width: "100%", widthMd: "100%", onClose: () => {
|
|
18
|
+
if (onCancel)
|
|
19
|
+
onCancel();
|
|
20
|
+
}, footer: (0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Button_1.default, { onClick: onCancel, children: t('cancel') }), (0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, onClick: () => {
|
|
21
|
+
if (asset)
|
|
22
|
+
onOk(asset);
|
|
23
|
+
setAsset(undefined);
|
|
24
|
+
}, disabled: !asset, children: t('confirm') })] }), children: (0, jsx_runtime_1.jsx)(ImageUpload_1.default, { tenantID: tenantID, apiUrl: apiURL, uploadMultipleImages: false, maxNumberOfVisualizedUploads: 1, maxFileSizeInMB: 100, uploadUrl: uploadAssetURL, useImageCrop: false, allowedMimeTypes: constants_1.allowedMediaTypes, fileList: asset
|
|
25
|
+
? [
|
|
26
|
+
{
|
|
27
|
+
uid: `-1`,
|
|
28
|
+
name: asset.assetID,
|
|
29
|
+
status: 'done',
|
|
30
|
+
thumbUrl: (0, media_1.getResourceUrl)({
|
|
31
|
+
resourceURI: asset.assetURL,
|
|
32
|
+
tenantID,
|
|
33
|
+
apiURL,
|
|
34
|
+
sessionID,
|
|
35
|
+
}),
|
|
36
|
+
},
|
|
37
|
+
]
|
|
38
|
+
: [], uploadMessage: t('media.mediaUploadMessage'), imageProportions: 1, onUploadFinished: (file) => {
|
|
39
|
+
let newAsset = file.response.asset;
|
|
40
|
+
let response = file.response;
|
|
41
|
+
if (response.resultCode === 0) {
|
|
42
|
+
setAsset(newAsset);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
console.error(response, file);
|
|
46
|
+
Message_1.default.error(t((0, error_1.getErrori18nKey)(response.resultCode)));
|
|
47
|
+
}
|
|
48
|
+
}, onFileChanged: (_assetID, asset) => {
|
|
49
|
+
setAsset(a => ({
|
|
50
|
+
...(a || {}),
|
|
51
|
+
...asset,
|
|
52
|
+
}));
|
|
53
|
+
}, onRemove: async (file) => {
|
|
54
|
+
const resp = await deleteAsset(authToken, file.thumbUrl);
|
|
55
|
+
if (resp.resultCode === 0) {
|
|
56
|
+
setAsset(undefined);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
console.error(resp, file);
|
|
60
|
+
Message_1.default.error(t((0, error_1.getErrori18nKey)(resp.resultCode)));
|
|
61
|
+
}
|
|
62
|
+
return resp.resultCode === 0;
|
|
63
|
+
} }) }));
|
|
64
|
+
};
|
|
65
|
+
exports.default = AttachmentMediaModal;
|
|
66
|
+
//# sourceMappingURL=AttachmentMediaModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AttachmentMediaModal.js","sourceRoot":"","sources":["../../../src/components/AttachmentMediaModal/AttachmentMediaModal.tsx"],"names":[],"mappings":";;;;AACA,iCAAwC;AACxC,iDAA+C;AAC/C,+CAAsD;AACtD,uDAA4D;AAC5D,+CAAqD;AACrD,gEAAgC;AAChC,oEAAoC;AACpC,kEAAkC;AAClC,qFAAqD;AAcrD,MAAM,oBAAoB,GAAG,CAAC,EAC5B,OAAO,EACP,SAAS,EACT,SAAS,EACT,QAAQ,EACR,cAAc,EACd,WAAW,EACX,QAAQ,EACR,IAAI,EACJ,MAAM,GACA,EAAE,EAAE;IACV,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,8BAAc,GAAE,CAAC;IAC/B,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,GAAS,CAAC;IAE5C,OAAO,CACL,uBAAC,eAAK,IACJ,IAAI,EAAE,OAAO,EACb,KAAK,EAAE,CAAC,CAAC,qBAAqB,CAAC,EAC/B,SAAS,EAAC,wBAAwB,EAClC,QAAQ,QACR,KAAK,EAAC,MAAM,EACZ,OAAO,EAAC,MAAM,EACd,OAAO,EAAE,GAAG,EAAE;YACZ,IAAI,QAAQ;gBAAE,QAAQ,EAAE,CAAC;QAC3B,CAAC,EACD,MAAM,EACJ,6DACE,uBAAC,gBAAM,IAAC,OAAO,EAAE,QAAQ,YAAG,CAAC,CAAC,QAAQ,CAAC,GAAU,EACjD,uBAAC,gBAAM,IACL,OAAO,QACP,OAAO,EAAE,GAAG,EAAE;wBACZ,IAAI,KAAK;4BAAE,IAAI,CAAC,KAAK,CAAC,CAAC;wBACvB,QAAQ,CAAC,SAAS,CAAC,CAAC;oBACtB,CAAC,EACD,QAAQ,EAAE,CAAC,KAAK,YAEf,CAAC,CAAC,SAAS,CAAC,GACN,IACR,YAGL,uBAAC,qBAAW,IACV,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,EACd,oBAAoB,EAAE,KAAK,EAC3B,4BAA4B,EAAE,CAAC,EAC/B,eAAe,EAAE,GAAG,EACpB,SAAS,EAAE,cAAc,EACzB,YAAY,EAAE,KAAK,EACnB,gBAAgB,EAAE,6BAAiB,EACnC,QAAQ,EACN,KAAK;gBACH,CAAC,CAAC;oBACE;wBACE,GAAG,EAAE,IAAI;wBACT,IAAI,EAAE,KAAK,CAAC,OAAO;wBACnB,MAAM,EAAE,MAAM;wBACd,QAAQ,EAAE,IAAA,sBAAc,EAAC;4BACvB,WAAW,EAAE,KAAK,CAAC,QAAQ;4BAC3B,QAAQ;4BACR,MAAM;4BACN,SAAS;yBACV,CAAC;qBACH;iBACF;gBACH,CAAC,CAAC,EAAE,EAER,aAAa,EAAE,CAAC,CAAC,0BAA0B,CAAC,EAC5C,gBAAgB,EAAE,CAAC,EACnB,gBAAgB,EAAE,CAAC,IAAS,EAAE,EAAE;gBAC9B,IAAI,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAc,CAAC;gBAC5C,IAAI,QAAQ,GAAG,IAAI,CAAC,QAAwB,CAAC;gBAC7C,IAAI,QAAQ,CAAC,UAAU,KAAK,CAAC,EAAE;oBAC7B,QAAQ,CAAC,QAAQ,CAAC,CAAC;iBACpB;qBAAM;oBACL,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;oBAC9B,iBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,IAAA,uBAAe,EAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;iBACxD;YACH,CAAC,EACD,aAAa,EAAE,CAAC,QAAgB,EAAE,KAAqB,EAAE,EAAE;gBACzD,QAAQ,CACN,CAAC,CAAC,EAAE,CACF,CAAC;oBACC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;oBACZ,GAAG,KAAK;iBACC,CAAA,CACd,CAAC;YACJ,CAAC,EACD,QAAQ,EAAE,KAAK,EAAE,IAAS,EAAE,EAAE;gBAC5B,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACzD,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,EAAE;oBACzB,QAAQ,CAAC,SAAS,CAAC,CAAC;iBACrB;qBAAM;oBACL,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;oBAC1B,iBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,IAAA,uBAAe,EAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;iBACpD;gBAED,OAAO,IAAI,CAAC,UAAU,KAAK,CAAC,CAAC;YAC/B,CAAC,GACD,GACI,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,oBAAoB,CAAC"}
|
|
@@ -18,7 +18,8 @@ const Refresh_1 = tslib_1.__importDefault(require("../icons/Refresh"));
|
|
|
18
18
|
const Clear_1 = tslib_1.__importDefault(require("../icons/Clear"));
|
|
19
19
|
const DeepThought_1 = tslib_1.__importDefault(require("../icons/DeepThought"));
|
|
20
20
|
const Group_1 = tslib_1.__importDefault(require("../icons/Group"));
|
|
21
|
-
const
|
|
21
|
+
const User_1 = tslib_1.__importDefault(require("../icons/User"));
|
|
22
|
+
const Header = ({ className, memori, tenant, history, position, setShowPositionDrawer, setShowSettingsDrawer, setShowKnownFactsDrawer, setShowExpertsDrawer, speakerMuted, setSpeakerMuted, hasUserActivatedSpeak = false, showShare = true, showSettings = true, showSpeaker = true, showReload = false, showClear = false, showLogin = true, setShowLoginDrawer, clearHistory, loginToken, user, sessionID, }) => {
|
|
22
23
|
const { t } = (0, react_i18next_1.useTranslation)();
|
|
23
24
|
const [fullScreenAvailable, setFullScreenAvailable] = (0, react_1.useState)(false);
|
|
24
25
|
const [fullScreen, setFullScreen] = (0, react_1.useState)(false);
|
|
@@ -40,7 +41,7 @@ const Header = ({ className, memori, tenant, history, position, setShowPositionD
|
|
|
40
41
|
document.exitFullscreen();
|
|
41
42
|
setFullScreen(false);
|
|
42
43
|
}
|
|
43
|
-
} })), memori.enableDeepThought && !!loginToken && (user === null || user === void 0 ? void 0 : user.pAndCUAccepted) && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: !!sessionID && !!hasUserActivatedSpeak, shape: "circle", icon: (0, jsx_runtime_1.jsx)(DeepThought_1.default, {}), className: "memori-header--button memori-header--button--knownfacts", disabled: !hasUserActivatedSpeak || !sessionID, onClick: () => setShowKnownFactsDrawer(true), title: t('knownFacts.title') || 'Known facts' })), memori.enableBoardOfExperts && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", icon: (0, jsx_runtime_1.jsx)(Group_1.default, {}), className: "memori-header--button memori-header--button--experts", disabled: !hasUserActivatedSpeak || !sessionID, onClick: () => setShowExpertsDrawer(true), title: t('widget.showExpertsInTheBoard') || 'Experts in this board' })), showSpeaker && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", className: "memori-header--button memori-header--button--speaker", icon: speakerMuted ? (0, jsx_runtime_1.jsx)(SoundDeactivated_1.default, {}) : (0, jsx_runtime_1.jsx)(Sound_1.default, {}), onClick: () => setSpeakerMuted(!speakerMuted), title: t('widget.sound') || 'Sound' })), (0, jsx_runtime_1.jsx)(ExportHistoryButton_1.default, { history: history, memori: memori, className: "memori-header--button memori-header--button--export", disabled: !hasUserActivatedSpeak || history.length === 0 }), showSettings && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", className: "memori-header--button memori-header--button-settings", icon: (0, jsx_runtime_1.jsx)(Setting_1.default, {}), onClick: () => setShowSettingsDrawer(true), title: t('widget.settings') || 'Settings' })), showShare && ((0, jsx_runtime_1.jsx)(ShareButton_1.default, { className: "memori-header--button memori-header--button-share", title: memori.name, tenant: tenant, showQrCode: true, align: "left" }))] }));
|
|
44
|
+
} })), memori.enableDeepThought && !!loginToken && (user === null || user === void 0 ? void 0 : user.pAndCUAccepted) && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: !!sessionID && !!hasUserActivatedSpeak, shape: "circle", icon: (0, jsx_runtime_1.jsx)(DeepThought_1.default, {}), className: "memori-header--button memori-header--button--knownfacts", disabled: !hasUserActivatedSpeak || !sessionID, onClick: () => setShowKnownFactsDrawer(true), title: t('knownFacts.title') || 'Known facts' })), memori.enableBoardOfExperts && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", icon: (0, jsx_runtime_1.jsx)(Group_1.default, {}), className: "memori-header--button memori-header--button--experts", disabled: !hasUserActivatedSpeak || !sessionID, onClick: () => setShowExpertsDrawer(true), title: t('widget.showExpertsInTheBoard') || 'Experts in this board' })), showSpeaker && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", className: "memori-header--button memori-header--button--speaker", icon: speakerMuted ? (0, jsx_runtime_1.jsx)(SoundDeactivated_1.default, {}) : (0, jsx_runtime_1.jsx)(Sound_1.default, {}), onClick: () => setSpeakerMuted(!speakerMuted), title: t('widget.sound') || 'Sound' })), (0, jsx_runtime_1.jsx)(ExportHistoryButton_1.default, { history: history, memori: memori, className: "memori-header--button memori-header--button--export", disabled: !hasUserActivatedSpeak || history.length === 0 }), showSettings && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", className: "memori-header--button memori-header--button-settings", icon: (0, jsx_runtime_1.jsx)(Setting_1.default, {}), onClick: () => setShowSettingsDrawer(true), title: t('widget.settings') || 'Settings' })), showShare && ((0, jsx_runtime_1.jsx)(ShareButton_1.default, { className: "memori-header--button memori-header--button-share", title: memori.name, tenant: tenant, showQrCode: true, align: "left" })), showLogin && ((0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, shape: "circle", className: "memori-header--button memori-header--button-login", icon: (0, jsx_runtime_1.jsx)(User_1.default, {}), onClick: () => setShowLoginDrawer(true), title: loginToken ? t('login.user') || 'User' : t('login.login') || 'Login' }))] }));
|
|
44
45
|
};
|
|
45
46
|
exports.default = Header;
|
|
46
47
|
//# sourceMappingURL=Header.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../src/components/Header/Header.tsx"],"names":[],"mappings":";;;;AAAA,iCAAmD;AACnD,oEAA4B;AAQ5B,kEAAkC;AAClC,2EAA2C;AAC3C,yFAAyD;AACzD,mEAAmC;AACnC,iDAA+C;AAC/C,6GAA6E;AAC7E,uEAAuC;AACvC,qFAAqD;AACrD,qFAAqD;AACrD,6EAA6C;AAC7C,uEAAuC;AACvC,mEAAmC;AACnC,+EAA+C;AAC/C,mEAAmC;
|
|
1
|
+
{"version":3,"file":"Header.js","sourceRoot":"","sources":["../../../src/components/Header/Header.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
legend.helper {
|
|
2
|
+
display: inline-block;
|
|
3
|
+
width: auto;
|
|
4
|
+
border: 0;
|
|
5
|
+
margin: 0;
|
|
6
|
+
margin-bottom: 1rem;
|
|
7
|
+
font-size: 0.9em;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
legend.helper p {
|
|
11
|
+
margin-bottom: 0;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.memori--upload .ant-upload-list-picture-card-container,
|
|
15
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card {
|
|
16
|
+
width: auto;
|
|
17
|
+
min-width: 100px;
|
|
18
|
+
max-width: 200px;
|
|
19
|
+
height: auto;
|
|
20
|
+
min-height: 100px;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card {
|
|
24
|
+
flex-direction: column;
|
|
25
|
+
align-items: center;
|
|
26
|
+
justify-content: center;
|
|
27
|
+
padding: 2rem 1.5rem;
|
|
28
|
+
border: 2px var(--medium-gray) dashed;
|
|
29
|
+
border-radius: 7px;
|
|
30
|
+
background: none;
|
|
31
|
+
opacity: 0.7;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card .ant-upload {
|
|
35
|
+
transition: color 0.3s ease;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card:hover,
|
|
39
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card:focus {
|
|
40
|
+
border-color: var(--memori-primary);
|
|
41
|
+
opacity: 1;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card:hover .ant-upload,
|
|
45
|
+
.memori--upload .ant-upload.ant-upload-select-picture-card:focus .ant-upload {
|
|
46
|
+
color: var(--memori-primary);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.memori--upload .ant-upload-list {
|
|
50
|
+
display: flex;
|
|
51
|
+
flex-wrap: wrap;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.memori--upload .ant-upload-list-item {
|
|
55
|
+
overflow: hidden;
|
|
56
|
+
padding: 0;
|
|
57
|
+
border: 0;
|
|
58
|
+
border-radius: 5px;
|
|
59
|
+
box-shadow: 0 0 0.5rem 0 rgba(0, 0, 0, 0.1);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.memori--upload .ant-upload-list-picture-card-container {
|
|
63
|
+
margin-bottom: 1rem;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.memori--list-item-wrapper {
|
|
67
|
+
position: relative;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.memori--list-item-wrapper .ant-spin-nested-loading,
|
|
71
|
+
.memori--list-item-wrapper .ant-spin-container {
|
|
72
|
+
height: 100%;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
.memori--list-item-wrapper figure {
|
|
76
|
+
margin-bottom: 0;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.memori--list-item-wrapper figure img {
|
|
80
|
+
max-height: 200px;
|
|
81
|
+
border-radius: 5px;
|
|
82
|
+
object-fit: contain;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
.memori--list-item-wrapper figure figcaption {
|
|
86
|
+
padding: 1rem;
|
|
87
|
+
font-size: 0.8rem;
|
|
88
|
+
text-align: center;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
.memori--list-item-wrapper .ant-upload-list-item-error .ant-upload-list-item-name {
|
|
92
|
+
position: static;
|
|
93
|
+
margin: 0 0 1rem;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.memori--list-item-wrapper .list-item-actions {
|
|
97
|
+
position: absolute;
|
|
98
|
+
top: 50%;
|
|
99
|
+
left: 50%;
|
|
100
|
+
display: flex;
|
|
101
|
+
overflow: hidden;
|
|
102
|
+
width: 0;
|
|
103
|
+
height: 0;
|
|
104
|
+
align-items: center;
|
|
105
|
+
justify-content: center;
|
|
106
|
+
border-radius: 5px;
|
|
107
|
+
background: rgba(0, 0, 0, 0.1);
|
|
108
|
+
opacity: 0;
|
|
109
|
+
transition: all 0.2s ease;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
.attachment-media-modal .memori-modal--panel {
|
|
113
|
+
min-width: 50%;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
.ant-upload-list-item-container {
|
|
117
|
+
width: 200px !important;
|
|
118
|
+
height: auto !important;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
.ant-upload.ant-upload-select {
|
|
122
|
+
width: 200px !important;
|
|
123
|
+
height: 200px !important;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
.memori--list-item-wrapper .list-item-actions a.action-button,
|
|
127
|
+
.memori--list-item-wrapper .list-item-actions button.action-button {
|
|
128
|
+
color: #fff;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
.memori--list-item-wrapper .list-item-actions a.action-button + .action-button,
|
|
132
|
+
.memori--list-item-wrapper .list-item-actions button.action-button + .action-button {
|
|
133
|
+
margin-left: 0.5rem;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
.memori--list-item-wrapper .list-item-actions a.action-button:hover,
|
|
137
|
+
.memori--list-item-wrapper .list-item-actions button.action-button:hover,
|
|
138
|
+
.memori--list-item-wrapper .list-item-actions a.action-button:focus,
|
|
139
|
+
.memori--list-item-wrapper .list-item-actions button.action-button:focus {
|
|
140
|
+
color: #fff;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.memori--list-item-wrapper:hover .list-item-actions,
|
|
144
|
+
.memori--list-item-wrapper:focus .list-item-actions {
|
|
145
|
+
top: 0;
|
|
146
|
+
left: 0;
|
|
147
|
+
width: 100%;
|
|
148
|
+
height: 100%;
|
|
149
|
+
background: rgba(0, 0, 0, 0.4);
|
|
150
|
+
opacity: 1;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
.media-title-label {
|
|
154
|
+
display: block;
|
|
155
|
+
margin-bottom: 0.5rem;
|
|
156
|
+
font-size: 0.9rem;
|
|
157
|
+
font-weight: 600;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
.media-title-input {
|
|
161
|
+
width: 100%;
|
|
162
|
+
padding: 0.5rem 0.75rem;
|
|
163
|
+
border: 1px solid #d9d9d9;
|
|
164
|
+
border-radius: 5px;
|
|
165
|
+
background: #fff;
|
|
166
|
+
font-size: 0.9rem;
|
|
167
|
+
font-weight: 400;
|
|
168
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { UploadFile } from 'antd/lib/upload/interface';
|
|
2
|
+
import { Asset } from '@memori.ai/memori-api-client/dist/types';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
export interface Props {
|
|
5
|
+
uploadMultipleImages: boolean;
|
|
6
|
+
maxNumberOfVisualizedUploads?: number;
|
|
7
|
+
fileList?: any[];
|
|
8
|
+
uploadUrl: string;
|
|
9
|
+
apiUrl?: string;
|
|
10
|
+
tenantID: string;
|
|
11
|
+
maxFileSizeInMB?: number;
|
|
12
|
+
fileResolution?: number[];
|
|
13
|
+
useImageCrop?: boolean;
|
|
14
|
+
uploadMessage: string;
|
|
15
|
+
imageProportions?: number;
|
|
16
|
+
imageProportionsHelper?: string;
|
|
17
|
+
allowedMimeTypes?: string[];
|
|
18
|
+
onRemove?: (file: UploadFile<any>) => Promise<boolean>;
|
|
19
|
+
onUploadFinished?: (file: UploadFile) => void;
|
|
20
|
+
onFileChanged?: (assetID: string, asset: Partial<Asset>) => void;
|
|
21
|
+
onFileNotValid?: () => void;
|
|
22
|
+
disabled?: boolean;
|
|
23
|
+
showHelper?: boolean;
|
|
24
|
+
additionalHelper?: string;
|
|
25
|
+
resourceType?: 'avatar' | 'cover' | undefined;
|
|
26
|
+
}
|
|
27
|
+
declare const ImageUpload: React.FC<Props>;
|
|
28
|
+
export default ImageUpload;
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const Message_1 = tslib_1.__importDefault(require("../ui/Message"));
|
|
7
|
+
const Button_1 = tslib_1.__importDefault(require("../ui/Button"));
|
|
8
|
+
const Tooltip_1 = tslib_1.__importDefault(require("../ui/Tooltip"));
|
|
9
|
+
const Modal_1 = tslib_1.__importDefault(require("../ui/Modal"));
|
|
10
|
+
const Spin_1 = tslib_1.__importDefault(require("../ui/Spin"));
|
|
11
|
+
const Upload_1 = tslib_1.__importDefault(require("antd/lib/upload/Upload"));
|
|
12
|
+
const antd_img_crop_1 = tslib_1.__importDefault(require("antd-img-crop"));
|
|
13
|
+
const react_i18next_1 = require("react-i18next");
|
|
14
|
+
const Edit_1 = tslib_1.__importDefault(require("../icons/Edit"));
|
|
15
|
+
const Delete_1 = tslib_1.__importDefault(require("../icons/Delete"));
|
|
16
|
+
const MediaItemWidget_1 = require("../MediaWidget/MediaItemWidget");
|
|
17
|
+
const media_1 = require("../../helpers/media");
|
|
18
|
+
const imgMimeTypes = ['image/jpeg', 'image/png', 'image/jpg', 'image/gif'];
|
|
19
|
+
const UploadListItem = ({ originNode, file, tenantID, apiUrl, actions, resourceType, }) => {
|
|
20
|
+
var _a, _b, _c, _d;
|
|
21
|
+
const { t } = (0, react_i18next_1.useTranslation)();
|
|
22
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: `memori--list-item-wrapper${file.status === 'uploading' ? ` listItemUploading` : ''}`, children: [(0, jsx_runtime_1.jsx)(Spin_1.default, { spinning: file.status === 'uploading', children: file.status === 'error' ? ((0, jsx_runtime_1.jsx)(Tooltip_1.default, { content: t('media.uploadError'), children: originNode.props.children })) : ((0, jsx_runtime_1.jsx)(MediaItemWidget_1.RenderMediaItem, { item: {
|
|
23
|
+
mediumID: file.uid,
|
|
24
|
+
mimeType: file.status === 'uploading'
|
|
25
|
+
? 'image/png'
|
|
26
|
+
: ((_a = file.name) === null || _a === void 0 ? void 0 : _a.endsWith('.glb'))
|
|
27
|
+
? 'model/gltf-binary'
|
|
28
|
+
: file.type || 'image/png',
|
|
29
|
+
title: (_b = file.name) !== null && _b !== void 0 ? _b : '',
|
|
30
|
+
url: file.status === 'uploading'
|
|
31
|
+
? ''
|
|
32
|
+
: ((_d = (_c = file.response) === null || _c === void 0 ? void 0 : _c.asset) === null || _d === void 0 ? void 0 : _d.assetURL)
|
|
33
|
+
? file.response.asset.assetURL
|
|
34
|
+
: (0, media_1.getResourceUrl)({
|
|
35
|
+
type: resourceType,
|
|
36
|
+
resourceURI: file.thumbUrl,
|
|
37
|
+
tenantID,
|
|
38
|
+
apiURL: apiUrl,
|
|
39
|
+
}),
|
|
40
|
+
content: `${(0, media_1.getResourceUrl)({
|
|
41
|
+
resourceURI: file.thumbUrl,
|
|
42
|
+
type: resourceType,
|
|
43
|
+
apiURL: apiUrl,
|
|
44
|
+
})}`,
|
|
45
|
+
}, preview: false })) }), (file.status === 'success' || file.status === 'done') && ((0, jsx_runtime_1.jsxs)("div", { className: "list-item-actions", children: [(0, jsx_runtime_1.jsx)(Button_1.default, { outlined: true, shape: "circle", icon: (0, jsx_runtime_1.jsx)(Edit_1.default, {}), className: "action-button", title: t('edit') || 'Edit', onClick: () => actions === null || actions === void 0 ? void 0 : actions.download(file) }), (0, jsx_runtime_1.jsx)(Button_1.default, { outlined: true, shape: "circle", icon: (0, jsx_runtime_1.jsx)(Delete_1.default, {}), className: "action-button", title: t('delete') || 'Delete', onClick: () => actions === null || actions === void 0 ? void 0 : actions.remove(file) })] }))] }));
|
|
46
|
+
};
|
|
47
|
+
const ImageUpload = ({ uploadMultipleImages, maxNumberOfVisualizedUploads, uploadUrl, apiUrl, tenantID, fileList, maxFileSizeInMB = 2, fileResolution, useImageCrop, uploadMessage, imageProportions = 1, imageProportionsHelper, allowedMimeTypes, onRemove, onFileChanged, onUploadFinished, onFileNotValid, disabled, showHelper, additionalHelper, resourceType, }) => {
|
|
48
|
+
var _a;
|
|
49
|
+
const { t } = (0, react_i18next_1.useTranslation)();
|
|
50
|
+
const [internalFileList, setInternalFileList] = (0, react_1.useState)((fileList !== null && fileList !== void 0 ? fileList : []));
|
|
51
|
+
const onChange = (info) => {
|
|
52
|
+
setInternalFileList(info.fileList.map(f => { var _a; return ({ ...f, status: (_a = f.status) !== null && _a !== void 0 ? _a : 'error' }); }));
|
|
53
|
+
if (info.file.status === 'done') {
|
|
54
|
+
onUploadFinished && onUploadFinished(info.file);
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
const beforeUpload = (file) => {
|
|
58
|
+
const isAllowed = (allowedMimeTypes !== null && allowedMimeTypes !== void 0 ? allowedMimeTypes : imgMimeTypes).find(x => x === file.type);
|
|
59
|
+
if (!isAllowed && file.type) {
|
|
60
|
+
console.debug('File not allowed', file, allowedMimeTypes !== null && allowedMimeTypes !== void 0 ? allowedMimeTypes : imgMimeTypes);
|
|
61
|
+
Message_1.default.error(t('media.uploadMimeTypeNotAllowed'));
|
|
62
|
+
onFileNotValid && onFileNotValid();
|
|
63
|
+
return Promise.reject(t('media.uploadMimeTypeNotAllowed'));
|
|
64
|
+
}
|
|
65
|
+
const isLimitedSize = file.size / 1024 / 1024 < (maxFileSizeInMB !== null && maxFileSizeInMB !== void 0 ? maxFileSizeInMB : 2);
|
|
66
|
+
if (!isLimitedSize) {
|
|
67
|
+
Message_1.default.error(t('media.uploadSizeLimitMessage', { size: maxFileSizeInMB }));
|
|
68
|
+
onFileNotValid && onFileNotValid();
|
|
69
|
+
return Promise.reject(t('media.uploadSizeLimitMessage', { size: maxFileSizeInMB }));
|
|
70
|
+
}
|
|
71
|
+
if (fileResolution && fileResolution.length) {
|
|
72
|
+
const reader = new FileReader();
|
|
73
|
+
reader.readAsDataURL(file);
|
|
74
|
+
return new Promise((resolve, reject) => {
|
|
75
|
+
reader.addEventListener('load', event => {
|
|
76
|
+
var _a, _b, _c;
|
|
77
|
+
var newImg = new Image();
|
|
78
|
+
newImg.style.padding = '0px';
|
|
79
|
+
newImg.style.margin = '0px';
|
|
80
|
+
newImg.onload = () => {
|
|
81
|
+
let ok = newImg.width === fileResolution[0] &&
|
|
82
|
+
newImg.height === fileResolution[1];
|
|
83
|
+
if (!ok) {
|
|
84
|
+
Message_1.default.error(t('media.uploadWrongResolutionMessage', {
|
|
85
|
+
width: fileResolution[0],
|
|
86
|
+
height: fileResolution[1],
|
|
87
|
+
}));
|
|
88
|
+
reject();
|
|
89
|
+
if (onFileNotValid)
|
|
90
|
+
onFileNotValid();
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
resolve(file);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
newImg.src = (_c = (_b = (_a = event.target) === null || _a === void 0 ? void 0 : _a.result) === null || _b === void 0 ? void 0 : _b.toString()) !== null && _c !== void 0 ? _c : '';
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
else
|
|
101
|
+
return Promise.resolve(file);
|
|
102
|
+
};
|
|
103
|
+
const [fileTitleModal, setFileTitleModal] = (0, react_1.useState)();
|
|
104
|
+
const upload = ((0, jsx_runtime_1.jsx)(Upload_1.default, { className: "memori--upload", disabled: disabled !== null && disabled !== void 0 ? disabled : false, accept: ((_a = (allowedMimeTypes !== null && allowedMimeTypes !== void 0 ? allowedMimeTypes : imgMimeTypes)) === null || _a === void 0 ? void 0 : _a.join(',')) +
|
|
105
|
+
';capture=camera,camcorder', action: uploadUrl, listType: "picture-card", showUploadList: {
|
|
106
|
+
showPreviewIcon: true,
|
|
107
|
+
showRemoveIcon: true,
|
|
108
|
+
showDownloadIcon: true,
|
|
109
|
+
downloadIcon: (0, jsx_runtime_1.jsx)(Edit_1.default, { title: t('edit') || 'Edit' }),
|
|
110
|
+
}, beforeUpload: beforeUpload, supportServerRender: true, fileList: internalFileList, multiple: uploadMultipleImages, maxCount: maxNumberOfVisualizedUploads || (uploadMultipleImages ? 100 : 1), onChange: onChange, onRemove: onRemove, onDownload: file => {
|
|
111
|
+
var _a, _b;
|
|
112
|
+
let asset = (_a = file.response) === null || _a === void 0 ? void 0 : _a.asset;
|
|
113
|
+
if (asset) {
|
|
114
|
+
let title = asset.originalFileName && file.name.includes(asset.originalFileName)
|
|
115
|
+
? asset.originalFileName
|
|
116
|
+
: file.name;
|
|
117
|
+
setFileTitleModal({
|
|
118
|
+
...asset,
|
|
119
|
+
title: title !== null && title !== void 0 ? title : asset.title,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
setFileTitleModal({
|
|
124
|
+
assetID: file.uid,
|
|
125
|
+
title: (_b = file.name) !== null && _b !== void 0 ? _b : file.fileName,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
}, itemRender: (originNode, file, currFileList, actions) => ((0, jsx_runtime_1.jsx)(UploadListItem, { resourceType: resourceType, originNode: originNode, file: file, fileList: internalFileList || currFileList, actions: actions, tenantID: tenantID, apiUrl: apiUrl })), children: uploadMessage }));
|
|
129
|
+
return ((0, jsx_runtime_1.jsxs)("div", { "aria-live": "polite", children: [!!useImageCrop ? ((0, jsx_runtime_1.jsx)(antd_img_crop_1.default, { rotate: true, aspect: imageProportions, fillColor: 'transparent', modalCancel: t('cancel') || 'Cancel', modalMaskTransitionName: "none", modalTransitionName: "none", children: upload })) : (upload), (0, jsx_runtime_1.jsxs)(Modal_1.default, { open: !!fileTitleModal, title: t('media.editAttributes'), onClose: () => {
|
|
130
|
+
setFileTitleModal(undefined);
|
|
131
|
+
}, footer: (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {}), width: "100%", children: [(0, jsx_runtime_1.jsx)("label", { htmlFor: "media-title-input", className: "media-title-label", children: t('media.title') }), (0, jsx_runtime_1.jsx)("input", { id: "media-title-input", className: "media-title-input", type: "text", name: "title", defaultValue: (fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.title) || '', onChange: e => {
|
|
132
|
+
setFileTitleModal({
|
|
133
|
+
...fileTitleModal,
|
|
134
|
+
title: e.target.value,
|
|
135
|
+
});
|
|
136
|
+
} }), (0, jsx_runtime_1.jsxs)("div", { className: "memori-modal--footer", children: [(0, jsx_runtime_1.jsx)(Button_1.default, { onClick: () => {
|
|
137
|
+
setFileTitleModal(undefined);
|
|
138
|
+
}, children: t('cancel') }), (0, jsx_runtime_1.jsx)(Button_1.default, { primary: true, onClick: () => {
|
|
139
|
+
onFileChanged &&
|
|
140
|
+
(fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.assetID) &&
|
|
141
|
+
onFileChanged(fileTitleModal.assetID, {
|
|
142
|
+
...fileTitleModal,
|
|
143
|
+
});
|
|
144
|
+
setInternalFileList(fl => fl.map(f => {
|
|
145
|
+
var _a, _b;
|
|
146
|
+
return f.uid === (fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.assetID) ||
|
|
147
|
+
((_b = (_a = f.response) === null || _a === void 0 ? void 0 : _a.asset) === null || _b === void 0 ? void 0 : _b.assetID) === (fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.assetID)
|
|
148
|
+
? {
|
|
149
|
+
...f,
|
|
150
|
+
title: fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.title,
|
|
151
|
+
name: fileTitleModal === null || fileTitleModal === void 0 ? void 0 : fileTitleModal.title,
|
|
152
|
+
}
|
|
153
|
+
: f;
|
|
154
|
+
}));
|
|
155
|
+
setFileTitleModal(undefined);
|
|
156
|
+
}, children: t('confirm') })] })] }), showHelper && ((0, jsx_runtime_1.jsxs)("legend", { className: "helper", children: [(0, jsx_runtime_1.jsx)("p", { children: t(allowedMimeTypes
|
|
157
|
+
? 'media.uploadHelper'
|
|
158
|
+
: 'media.uploadHelperImages', {
|
|
159
|
+
size: maxFileSizeInMB !== null && maxFileSizeInMB !== void 0 ? maxFileSizeInMB : 2,
|
|
160
|
+
}) }), imageProportionsHelper && useImageCrop && ((0, jsx_runtime_1.jsxs)("p", { children: [t('media.scaleRatio'), ": ", imageProportionsHelper] })), additionalHelper && (0, jsx_runtime_1.jsx)("p", { children: additionalHelper })] }))] }));
|
|
161
|
+
};
|
|
162
|
+
exports.default = ImageUpload;
|
|
163
|
+
//# sourceMappingURL=ImageUpload.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ImageUpload.js","sourceRoot":"","sources":["../../../src/components/ImageUpload/ImageUpload.tsx"],"names":[],"mappings":";;;;AAEA,iCAAwC;AACxC,oEAAoC;AACpC,kEAAkC;AAClC,oEAAoC;AACpC,gEAAgC;AAChC,8DAA8B;AAC9B,4EAA4C;AAC5C,0EAAoC;AACpC,iDAA+C;AAC/C,iEAAiC;AACjC,qEAAqC;AACrC,oEAAiE;AACjE,+CAAqD;AAErD,MAAM,YAAY,GAAG,CAAC,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;AA2C3E,MAAM,cAAc,GAAG,CAAC,EACtB,UAAU,EACV,IAAI,EACJ,QAAQ,EACR,MAAM,EACN,OAAO,EACP,YAAY,GACQ,EAAE,EAAE;;IACxB,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,8BAAc,GAAE,CAAC;IAE/B,OAAO,CACL,iCACE,SAAS,EAAE,4BACT,IAAI,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EACvD,EAAE,aAEF,uBAAC,cAAI,IAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,KAAK,WAAW,YACxC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,CACzB,uBAAC,iBAAO,IAAC,OAAO,EAAE,CAAC,CAAC,mBAAmB,CAAC,YACrC,UAAU,CAAC,KAAK,CAAC,QAAQ,GAClB,CACX,CAAC,CAAC,CAAC,CACF,uBAAC,iCAAe,IACd,IAAI,EACF;wBACE,QAAQ,EAAE,IAAI,CAAC,GAAG;wBAClB,QAAQ,EACN,IAAI,CAAC,MAAM,KAAK,WAAW;4BACzB,CAAC,CAAC,WAAW;4BACb,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,CAAC,MAAM,CAAC;gCAC7B,CAAC,CAAC,mBAAmB;gCACrB,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,WAAW;wBAC9B,KAAK,EAAE,MAAA,IAAI,CAAC,IAAI,mCAAI,EAAE;wBACtB,GAAG,EACD,IAAI,CAAC,MAAM,KAAK,WAAW;4BACzB,CAAC,CAAC,EAAE;4BACJ,CAAC,CAAC,CAAA,MAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,KAAK,0CAAE,QAAQ;gCAChC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ;gCAC9B,CAAC,CAAC,IAAA,sBAAc,EAAC;oCACb,IAAI,EAAE,YAAY;oCAClB,WAAW,EAAE,IAAI,CAAC,QAAQ;oCAC1B,QAAQ;oCACR,MAAM,EAAE,MAAM;iCACf,CAAC;wBACR,OAAO,EAAE,GAAG,IAAA,sBAAc,EAAC;4BACzB,WAAW,EAAE,IAAI,CAAC,QAAQ;4BAC1B,IAAI,EAAE,YAAY;4BAClB,MAAM,EAAE,MAAM;yBACf,CAAC,EAAE;qBACK,EAEb,OAAO,EAAE,KAAK,GACd,CACH,GACI,EACN,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,IAAI,CACxD,iCAAK,SAAS,EAAC,mBAAmB,aAChC,uBAAC,gBAAM,IACL,QAAQ,QACR,KAAK,EAAC,QAAQ,EACd,IAAI,EAAE,uBAAC,cAAI,KAAG,EACd,SAAS,EAAC,eAAe,EACzB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,MAAM,EAC1B,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAC,IAAI,CAAC,GACtC,EACF,uBAAC,gBAAM,IACL,QAAQ,QACR,KAAK,EAAC,QAAQ,EACd,IAAI,EAAE,uBAAC,gBAAM,KAAG,EAChB,SAAS,EAAC,eAAe,EACzB,KAAK,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,QAAQ,EAC9B,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,CAAC,IAAI,CAAC,GACpC,IACE,CACP,IACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,WAAW,GAAoB,CAAC,EACpC,oBAAoB,EACpB,4BAA4B,EAC5B,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,eAAe,GAAG,CAAC,EACnB,cAAc,EACd,YAAY,EACZ,aAAa,EACb,gBAAgB,GAAG,CAAC,EACpB,sBAAsB,EACtB,gBAAgB,EAChB,QAAQ,EACR,aAAa,EACb,gBAAgB,EAChB,cAAc,EACd,QAAQ,EACR,UAAU,EACV,gBAAgB,EAChB,YAAY,GACb,EAAE,EAAE;;IACH,MAAM,EAAE,CAAC,EAAE,GAAG,IAAA,8BAAc,GAAE,CAAC;IAE/B,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,IAAA,gBAAQ,EACtD,CAAC,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,EAAE,CAAU,CAC1B,CAAC;IAEF,MAAM,QAAQ,GAAG,CAAC,IAAmC,EAAE,EAAE;QACvD,mBAAmB,CACjB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,WAAC,OAAA,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,MAAA,CAAC,CAAC,MAAM,mCAAI,OAAO,EAAE,CAAC,CAAA,EAAA,CAAC,CAChE,CAAC;QACF,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;YAC/B,gBAAgB,IAAI,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACjD;IACH,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,CAAC,IAAS,EAAiB,EAAE;QAChD,MAAM,SAAS,GAAG,CAAC,gBAAgB,aAAhB,gBAAgB,cAAhB,gBAAgB,GAAI,YAAY,CAAC,CAAC,IAAI,CACvD,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,IAAI,CACrB,CAAC;QACF,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,EAAE;YAC3B,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,gBAAgB,aAAhB,gBAAgB,cAAhB,gBAAgB,GAAI,YAAY,CAAC,CAAC;YAC1E,iBAAO,CAAC,KAAK,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC;YACnD,cAAc,IAAI,cAAc,EAAE,CAAC;YACnC,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC;SAC5D;QACD,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,CAAC,eAAe,aAAf,eAAe,cAAf,eAAe,GAAI,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,aAAa,EAAE;YAClB,iBAAO,CAAC,KAAK,CACX,CAAC,CAAC,8BAA8B,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAC7D,CAAC;YACF,cAAc,IAAI,cAAc,EAAE,CAAC;YACnC,OAAO,OAAO,CAAC,MAAM,CACnB,CAAC,CAAC,8BAA8B,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAC7D,CAAC;SACH;QAED,IAAI,cAAc,IAAI,cAAc,CAAC,MAAM,EAAE;YAC3C,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAC3B,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;;oBACtC,IAAI,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;oBACzB,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;oBAC7B,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC;oBAE5B,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;wBACnB,IAAI,EAAE,GACJ,MAAM,CAAC,KAAK,KAAK,cAAc,CAAC,CAAC,CAAC;4BAClC,MAAM,CAAC,MAAM,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC;wBACtC,IAAI,CAAC,EAAE,EAAE;4BACP,iBAAO,CAAC,KAAK,CACX,CAAC,CAAC,oCAAoC,EAAE;gCACtC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC;gCACxB,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;6BAC1B,CAAC,CACH,CAAC;4BACF,MAAM,EAAE,CAAC;4BACT,IAAI,cAAc;gCAAE,cAAc,EAAE,CAAC;yBACtC;6BAAM;4BACL,OAAO,CAAC,IAAI,CAAC,CAAC;yBACf;oBACH,CAAC,CAAC;oBACF,MAAM,CAAC,GAAG,GAAG,MAAA,MAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,MAAM,0CAAE,QAAQ,EAAE,mCAAI,EAAE,CAAC;gBACtD,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;;YAAM,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC,CAAC;IAEF,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,IAAA,gBAAQ,GAAkB,CAAC;IAEvE,MAAM,MAAM,GAAG,CACb,uBAAC,gBAAM,IACL,SAAS,EAAC,gBAAgB,EAC1B,QAAQ,EAAE,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,KAAK,EAC3B,MAAM,EACJ,CAAA,MAAA,CAAC,gBAAgB,aAAhB,gBAAgB,cAAhB,gBAAgB,GAAI,YAAY,CAAC,0CAAE,IAAI,CAAC,GAAG,CAAC;YAC7C,2BAA2B,EAE7B,MAAM,EAAE,SAAS,EACjB,QAAQ,EAAC,cAAc,EACvB,cAAc,EAAE;YACd,eAAe,EAAE,IAAI;YACrB,cAAc,EAAE,IAAI;YACpB,gBAAgB,EAAE,IAAI;YACtB,YAAY,EAAE,uBAAC,cAAI,IAAC,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,MAAM,GAAI;SACnD,EACD,YAAY,EAAE,YAAY,EAC1B,mBAAmB,QACnB,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,EAAE,oBAAoB,EAC9B,QAAQ,EACN,4BAA4B,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAElE,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,IAAI,CAAC,EAAE;;YACjB,IAAI,KAAK,GAAG,MAAA,IAAI,CAAC,QAAQ,0CAAE,KAA0B,CAAC;YACtD,IAAI,KAAK,EAAE;gBACT,IAAI,KAAK,GACP,KAAK,CAAC,gBAAgB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,gBAAgB,CAAC;oBAClE,CAAC,CAAC,KAAK,CAAC,gBAAgB;oBACxB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;gBAChB,iBAAiB,CAAC;oBAChB,GAAG,KAAK;oBACR,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,KAAK,CAAC,KAAK;iBAC5B,CAAC,CAAC;aACJ;iBAAM;gBACL,iBAAiB,CAAC;oBAChB,OAAO,EAAE,IAAI,CAAC,GAAG;oBACjB,KAAK,EAAE,MAAA,IAAI,CAAC,IAAI,mCAAI,IAAI,CAAC,QAAQ;iBAClC,CAAC,CAAC;aACJ;QACH,CAAC,EACD,UAAU,EAAE,CAAC,UAAU,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,EAAE,CAAC,CACvD,uBAAC,cAAc,IACb,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,gBAAgB,IAAI,YAAY,EAC1C,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,GACd,CACH,YAEA,aAAa,GACP,CACV,CAAC;IAEF,OAAO,CACL,8CAAe,QAAQ,aACpB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAChB,uBAAC,uBAAO,IACN,MAAM,QACN,MAAM,EAAE,gBAAgB,EACxB,SAAS,EAAE,aAAa,EACxB,WAAW,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,QAAQ,EACpC,uBAAuB,EAAC,MAAM,EAC9B,mBAAmB,EAAC,MAAM,YAEzB,MAAM,GACC,CACX,CAAC,CAAC,CAAC,CACF,MAAM,CACP,EACD,wBAAC,eAAK,IACJ,IAAI,EAAE,CAAC,CAAC,cAAc,EACtB,KAAK,EAAE,CAAC,CAAC,sBAAsB,CAAC,EAChC,OAAO,EAAE,GAAG,EAAE;oBACZ,iBAAiB,CAAC,SAAS,CAAC,CAAC;gBAC/B,CAAC,EACD,MAAM,EAAE,kDAAK,EACb,KAAK,EAAC,MAAM,aAEZ,kCAAO,OAAO,EAAC,mBAAmB,EAAC,SAAS,EAAC,mBAAmB,YAC7D,CAAC,CAAC,aAAa,CAAC,GACX,EACR,kCACE,EAAE,EAAC,mBAAmB,EACtB,SAAS,EAAC,mBAAmB,EAC7B,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,OAAO,EACZ,YAAY,EAAE,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,KAAK,KAAI,EAAE,EACzC,QAAQ,EAAE,CAAC,CAAC,EAAE;4BACZ,iBAAiB,CAAC;gCAChB,GAAG,cAAc;gCACjB,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK;6BACtB,CAAC,CAAC;wBACL,CAAC,GACD,EAEF,iCAAK,SAAS,EAAC,sBAAsB,aACnC,uBAAC,gBAAM,IACL,OAAO,EAAE,GAAG,EAAE;oCACZ,iBAAiB,CAAC,SAAS,CAAC,CAAC;gCAC/B,CAAC,YAEA,CAAC,CAAC,QAAQ,CAAC,GACL,EACT,uBAAC,gBAAM,IACL,OAAO,QACP,OAAO,EAAE,GAAG,EAAE;oCACZ,aAAa;yCACX,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,OAAO,CAAA;wCACvB,aAAa,CAAC,cAAc,CAAC,OAAO,EAAE;4CACpC,GAAG,cAAc;yCAClB,CAAC,CAAC;oCACL,mBAAmB,CAAC,EAAE,CAAC,EAAE,CACvB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;;wCACT,OAAA,CAAC,CAAC,GAAG,MAAK,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,OAAO,CAAA;4CACjC,CAAA,MAAA,MAAA,CAAC,CAAC,QAAQ,0CAAE,KAAK,0CAAE,OAAO,OAAK,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,OAAO,CAAA;4CACpD,CAAC,CAAC;gDACE,GAAG,CAAC;gDACJ,KAAK,EAAE,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,KAAK;gDAC5B,IAAI,EAAE,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,KAAK;6CAC5B;4CACH,CAAC,CAAC,CAAC,CAAA;qCAAA,CACN,CACF,CAAC;oCACF,iBAAiB,CAAC,SAAS,CAAC,CAAC;gCAC/B,CAAC,YAEA,CAAC,CAAC,SAAS,CAAC,GACN,IACL,IACA,EACP,UAAU,IAAI,CACb,oCAAQ,SAAS,EAAC,QAAQ,aACxB,wCACG,CAAC,CACA,gBAAgB;4BACd,CAAC,CAAC,oBAAoB;4BACtB,CAAC,CAAC,0BAA0B,EAC9B;4BACE,IAAI,EAAE,eAAe,aAAf,eAAe,cAAf,eAAe,GAAI,CAAC;yBAC3B,CACF,GACC,EACH,sBAAsB,IAAI,YAAY,IAAI,CACzC,0CACG,CAAC,CAAC,kBAAkB,CAAC,QAAI,sBAAsB,IAC9C,CACL,EACA,gBAAgB,IAAI,wCAAI,gBAAgB,GAAK,IACvC,CACV,IACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,WAAW,CAAC"}
|