@sudobility/wildduck_client 0.0.14
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/README.md +354 -0
- package/dist/hooks/ServiceProvider.d.ts +15 -0
- package/dist/hooks/ServiceProvider.d.ts.map +1 -0
- package/dist/hooks/ServiceProvider.js +21 -0
- package/dist/hooks/ServiceProvider.js.map +1 -0
- package/dist/hooks/addresses/index.d.ts +2 -0
- package/dist/hooks/addresses/index.d.ts.map +1 -0
- package/dist/hooks/addresses/index.js +2 -0
- package/dist/hooks/addresses/index.js.map +1 -0
- package/dist/hooks/addresses/useWildduckGetAddresses.d.ts +232 -0
- package/dist/hooks/addresses/useWildduckGetAddresses.d.ts.map +1 -0
- package/dist/hooks/addresses/useWildduckGetAddresses.js +34 -0
- package/dist/hooks/addresses/useWildduckGetAddresses.js.map +1 -0
- package/dist/hooks/autoreply/index.d.ts +4 -0
- package/dist/hooks/autoreply/index.d.ts.map +1 -0
- package/dist/hooks/autoreply/index.js +4 -0
- package/dist/hooks/autoreply/index.js.map +1 -0
- package/dist/hooks/autoreply/useWildduckDeleteAutoreply.d.ts +13 -0
- package/dist/hooks/autoreply/useWildduckDeleteAutoreply.d.ts.map +1 -0
- package/dist/hooks/autoreply/useWildduckDeleteAutoreply.js +46 -0
- package/dist/hooks/autoreply/useWildduckDeleteAutoreply.js.map +1 -0
- package/dist/hooks/autoreply/useWildduckGetAutoreply.d.ts +172 -0
- package/dist/hooks/autoreply/useWildduckGetAutoreply.d.ts.map +1 -0
- package/dist/hooks/autoreply/useWildduckGetAutoreply.js +39 -0
- package/dist/hooks/autoreply/useWildduckGetAutoreply.js.map +1 -0
- package/dist/hooks/autoreply/useWildduckUpdateAutoreply.d.ts +13 -0
- package/dist/hooks/autoreply/useWildduckUpdateAutoreply.d.ts.map +1 -0
- package/dist/hooks/autoreply/useWildduckUpdateAutoreply.js +46 -0
- package/dist/hooks/autoreply/useWildduckUpdateAutoreply.js.map +1 -0
- package/dist/hooks/index.d.ts +19 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +16 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/mailboxes/index.d.ts +6 -0
- package/dist/hooks/mailboxes/index.d.ts.map +1 -0
- package/dist/hooks/mailboxes/index.js +6 -0
- package/dist/hooks/mailboxes/index.js.map +1 -0
- package/dist/hooks/mailboxes/useWildduckCreateMailbox.d.ts +13 -0
- package/dist/hooks/mailboxes/useWildduckCreateMailbox.d.ts.map +1 -0
- package/dist/hooks/mailboxes/useWildduckCreateMailbox.js +43 -0
- package/dist/hooks/mailboxes/useWildduckCreateMailbox.js.map +1 -0
- package/dist/hooks/mailboxes/useWildduckDeleteMailbox.d.ts +13 -0
- package/dist/hooks/mailboxes/useWildduckDeleteMailbox.d.ts.map +1 -0
- package/dist/hooks/mailboxes/useWildduckDeleteMailbox.js +48 -0
- package/dist/hooks/mailboxes/useWildduckDeleteMailbox.js.map +1 -0
- package/dist/hooks/mailboxes/useWildduckGetMailbox.d.ts +173 -0
- package/dist/hooks/mailboxes/useWildduckGetMailbox.d.ts.map +1 -0
- package/dist/hooks/mailboxes/useWildduckGetMailbox.js +47 -0
- package/dist/hooks/mailboxes/useWildduckGetMailbox.js.map +1 -0
- package/dist/hooks/mailboxes/useWildduckGetMailboxes.d.ts +233 -0
- package/dist/hooks/mailboxes/useWildduckGetMailboxes.d.ts.map +1 -0
- package/dist/hooks/mailboxes/useWildduckGetMailboxes.js +34 -0
- package/dist/hooks/mailboxes/useWildduckGetMailboxes.js.map +1 -0
- package/dist/hooks/mailboxes/useWildduckUpdateMailbox.d.ts +13 -0
- package/dist/hooks/mailboxes/useWildduckUpdateMailbox.d.ts.map +1 -0
- package/dist/hooks/mailboxes/useWildduckUpdateMailbox.js +48 -0
- package/dist/hooks/mailboxes/useWildduckUpdateMailbox.js.map +1 -0
- package/dist/hooks/messages/index.d.ts +12 -0
- package/dist/hooks/messages/index.d.ts.map +1 -0
- package/dist/hooks/messages/index.js +12 -0
- package/dist/hooks/messages/index.js.map +1 -0
- package/dist/hooks/messages/useWildduckDeleteMessage.d.ts +13 -0
- package/dist/hooks/messages/useWildduckDeleteMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckDeleteMessage.js +48 -0
- package/dist/hooks/messages/useWildduckDeleteMessage.js.map +1 -0
- package/dist/hooks/messages/useWildduckForwardMessage.d.ts +13 -0
- package/dist/hooks/messages/useWildduckForwardMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckForwardMessage.js +51 -0
- package/dist/hooks/messages/useWildduckForwardMessage.js.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessage.d.ts +653 -0
- package/dist/hooks/messages/useWildduckGetMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessage.js +37 -0
- package/dist/hooks/messages/useWildduckGetMessage.js.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessageAttachment.d.ts +13 -0
- package/dist/hooks/messages/useWildduckGetMessageAttachment.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessageAttachment.js +40 -0
- package/dist/hooks/messages/useWildduckGetMessageAttachment.js.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessageSource.d.ts +12 -0
- package/dist/hooks/messages/useWildduckGetMessageSource.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessageSource.js +35 -0
- package/dist/hooks/messages/useWildduckGetMessageSource.js.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessages.d.ts +11 -0
- package/dist/hooks/messages/useWildduckGetMessages.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckGetMessages.js +18 -0
- package/dist/hooks/messages/useWildduckGetMessages.js.map +1 -0
- package/dist/hooks/messages/useWildduckSearchMessages.d.ts +12 -0
- package/dist/hooks/messages/useWildduckSearchMessages.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckSearchMessages.js +46 -0
- package/dist/hooks/messages/useWildduckSearchMessages.js.map +1 -0
- package/dist/hooks/messages/useWildduckSendMessage.d.ts +13 -0
- package/dist/hooks/messages/useWildduckSendMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckSendMessage.js +48 -0
- package/dist/hooks/messages/useWildduckSendMessage.js.map +1 -0
- package/dist/hooks/messages/useWildduckSubmitDraft.d.ts +13 -0
- package/dist/hooks/messages/useWildduckSubmitDraft.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckSubmitDraft.js +44 -0
- package/dist/hooks/messages/useWildduckSubmitDraft.js.map +1 -0
- package/dist/hooks/messages/useWildduckUpdateMessage.d.ts +13 -0
- package/dist/hooks/messages/useWildduckUpdateMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckUpdateMessage.js +53 -0
- package/dist/hooks/messages/useWildduckUpdateMessage.js.map +1 -0
- package/dist/hooks/messages/useWildduckUploadMessage.d.ts +13 -0
- package/dist/hooks/messages/useWildduckUploadMessage.d.ts.map +1 -0
- package/dist/hooks/messages/useWildduckUploadMessage.js +51 -0
- package/dist/hooks/messages/useWildduckUploadMessage.js.map +1 -0
- package/dist/hooks/mocks.d.ts +354 -0
- package/dist/hooks/mocks.d.ts.map +1 -0
- package/dist/hooks/mocks.js +404 -0
- package/dist/hooks/mocks.js.map +1 -0
- package/dist/hooks/query-config.d.ts +9 -0
- package/dist/hooks/query-config.d.ts.map +1 -0
- package/dist/hooks/query-config.js +9 -0
- package/dist/hooks/query-config.js.map +1 -0
- package/dist/hooks/query-keys.d.ts +31 -0
- package/dist/hooks/query-keys.d.ts.map +1 -0
- package/dist/hooks/query-keys.js +40 -0
- package/dist/hooks/query-keys.js.map +1 -0
- package/dist/hooks/useServices.d.ts +14 -0
- package/dist/hooks/useServices.d.ts.map +1 -0
- package/dist/hooks/useServices.js +36 -0
- package/dist/hooks/useServices.js.map +1 -0
- package/dist/hooks/useWildduckAddresses.d.ts +67 -0
- package/dist/hooks/useWildduckAddresses.d.ts.map +1 -0
- package/dist/hooks/useWildduckAddresses.js +313 -0
- package/dist/hooks/useWildduckAddresses.js.map +1 -0
- package/dist/hooks/useWildduckAuth.d.ts +28 -0
- package/dist/hooks/useWildduckAuth.d.ts.map +1 -0
- package/dist/hooks/useWildduckAuth.js +249 -0
- package/dist/hooks/useWildduckAuth.js.map +1 -0
- package/dist/hooks/useWildduckFilters.d.ts +89 -0
- package/dist/hooks/useWildduckFilters.d.ts.map +1 -0
- package/dist/hooks/useWildduckFilters.js +209 -0
- package/dist/hooks/useWildduckFilters.js.map +1 -0
- package/dist/hooks/useWildduckHealth.d.ts +45 -0
- package/dist/hooks/useWildduckHealth.d.ts.map +1 -0
- package/dist/hooks/useWildduckHealth.js +110 -0
- package/dist/hooks/useWildduckHealth.js.map +1 -0
- package/dist/hooks/useWildduckMailboxes.d.ts +29 -0
- package/dist/hooks/useWildduckMailboxes.d.ts.map +1 -0
- package/dist/hooks/useWildduckMailboxes.js +195 -0
- package/dist/hooks/useWildduckMailboxes.js.map +1 -0
- package/dist/hooks/useWildduckMessages.d.ts +76 -0
- package/dist/hooks/useWildduckMessages.d.ts.map +1 -0
- package/dist/hooks/useWildduckMessages.js +264 -0
- package/dist/hooks/useWildduckMessages.js.map +1 -0
- package/dist/hooks/useWildduckQueries.d.ts +50 -0
- package/dist/hooks/useWildduckQueries.d.ts.map +1 -0
- package/dist/hooks/useWildduckQueries.js +640 -0
- package/dist/hooks/useWildduckQueries.js.map +1 -0
- package/dist/hooks/useWildduckSettings.d.ts +22 -0
- package/dist/hooks/useWildduckSettings.d.ts.map +1 -0
- package/dist/hooks/useWildduckSettings.js +153 -0
- package/dist/hooks/useWildduckSettings.js.map +1 -0
- package/dist/hooks/useWildduckUsers.d.ts +31 -0
- package/dist/hooks/useWildduckUsers.d.ts.map +1 -0
- package/dist/hooks/useWildduckUsers.js +114 -0
- package/dist/hooks/useWildduckUsers.js.map +1 -0
- package/dist/hooks/users/index.d.ts +12 -0
- package/dist/hooks/users/index.d.ts.map +1 -0
- package/dist/hooks/users/index.js +12 -0
- package/dist/hooks/users/index.js.map +1 -0
- package/dist/hooks/users/useWildduckCreateUser.d.ts +13 -0
- package/dist/hooks/users/useWildduckCreateUser.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckCreateUser.js +44 -0
- package/dist/hooks/users/useWildduckCreateUser.js.map +1 -0
- package/dist/hooks/users/useWildduckDeleteUser.d.ts +13 -0
- package/dist/hooks/users/useWildduckDeleteUser.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckDeleteUser.js +44 -0
- package/dist/hooks/users/useWildduckDeleteUser.js.map +1 -0
- package/dist/hooks/users/useWildduckGetUser.d.ts +397 -0
- package/dist/hooks/users/useWildduckGetUser.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckGetUser.js +45 -0
- package/dist/hooks/users/useWildduckGetUser.js.map +1 -0
- package/dist/hooks/users/useWildduckUpdateUser.d.ts +13 -0
- package/dist/hooks/users/useWildduckUpdateUser.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUpdateUser.js +44 -0
- package/dist/hooks/users/useWildduckUpdateUser.js.map +1 -0
- package/dist/hooks/users/useWildduckUser2FA.d.ts +25 -0
- package/dist/hooks/users/useWildduckUser2FA.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUser2FA.js +70 -0
- package/dist/hooks/users/useWildduckUser2FA.js.map +1 -0
- package/dist/hooks/users/useWildduckUserEncryption.d.ts +40 -0
- package/dist/hooks/users/useWildduckUserEncryption.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserEncryption.js +94 -0
- package/dist/hooks/users/useWildduckUserEncryption.js.map +1 -0
- package/dist/hooks/users/useWildduckUserForwarding.d.ts +44 -0
- package/dist/hooks/users/useWildduckUserForwarding.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserForwarding.js +122 -0
- package/dist/hooks/users/useWildduckUserForwarding.js.map +1 -0
- package/dist/hooks/users/useWildduckUserLimits.d.ts +63 -0
- package/dist/hooks/users/useWildduckUserLimits.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserLimits.js +60 -0
- package/dist/hooks/users/useWildduckUserLimits.js.map +1 -0
- package/dist/hooks/users/useWildduckUserProfile.d.ts +78 -0
- package/dist/hooks/users/useWildduckUserProfile.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserProfile.js +139 -0
- package/dist/hooks/users/useWildduckUserProfile.js.map +1 -0
- package/dist/hooks/users/useWildduckUserQuota.d.ts +31 -0
- package/dist/hooks/users/useWildduckUserQuota.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserQuota.js +66 -0
- package/dist/hooks/users/useWildduckUserQuota.js.map +1 -0
- package/dist/hooks/users/useWildduckUserSpam.d.ts +54 -0
- package/dist/hooks/users/useWildduckUserSpam.d.ts.map +1 -0
- package/dist/hooks/users/useWildduckUserSpam.js +137 -0
- package/dist/hooks/users/useWildduckUserSpam.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/network/index.d.ts +2 -0
- package/dist/network/index.d.ts.map +1 -0
- package/dist/network/index.js +2 -0
- package/dist/network/index.js.map +1 -0
- package/dist/network/wildduck-client.d.ts +54 -0
- package/dist/network/wildduck-client.d.ts.map +1 -0
- package/dist/network/wildduck-client.js +572 -0
- package/dist/network/wildduck-client.js.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/advanced-settings.d.ts +36 -0
- package/dist/utils/advanced-settings.d.ts.map +1 -0
- package/dist/utils/advanced-settings.js +99 -0
- package/dist/utils/advanced-settings.js.map +1 -0
- package/dist/utils/autoreply.d.ts +34 -0
- package/dist/utils/autoreply.d.ts.map +1 -0
- package/dist/utils/autoreply.js +39 -0
- package/dist/utils/autoreply.js.map +1 -0
- package/dist/utils/client.d.ts +4 -0
- package/dist/utils/client.d.ts.map +1 -0
- package/dist/utils/client.js +11 -0
- package/dist/utils/client.js.map +1 -0
- package/dist/utils/filters.d.ts +26 -0
- package/dist/utils/filters.d.ts.map +1 -0
- package/dist/utils/filters.js +50 -0
- package/dist/utils/filters.js.map +1 -0
- package/dist/utils/forwarding.d.ts +12 -0
- package/dist/utils/forwarding.d.ts.map +1 -0
- package/dist/utils/forwarding.js +29 -0
- package/dist/utils/forwarding.js.map +1 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +7 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/spam-settings.d.ts +21 -0
- package/dist/utils/spam-settings.d.ts.map +1 -0
- package/dist/utils/spam-settings.js +53 -0
- package/dist/utils/spam-settings.js.map +1 -0
- package/dist/utils/user-settings.d.ts +30 -0
- package/dist/utils/user-settings.d.ts.map +1 -0
- package/dist/utils/user-settings.js +21 -0
- package/dist/utils/user-settings.js.map +1 -0
- package/package.json +82 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessageAttachment.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessageAttachment.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM,WAAW,qCAAqC;IACpD,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAWD,eAAO,MAAM,+BAA+B,GAC1C,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,SAAQ,qCAA0C,gEAoDnD,CAAC;AAEF,MAAM,MAAM,qCAAqC,GAAG,UAAU,CAC5D,OAAO,+BAA+B,CACvC,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { useQuery } from "@tanstack/react-query";
|
|
3
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
4
|
+
export const useWildduckGetMessageAttachment = (networkClient, config, params = {}) => {
|
|
5
|
+
const { userAuth, mailboxId, messageId, attachmentId, devMode = false, } = params;
|
|
6
|
+
const api = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
return useQuery({
|
|
8
|
+
queryKey: [
|
|
9
|
+
"wildduck-message-attachment",
|
|
10
|
+
userAuth?.userId,
|
|
11
|
+
mailboxId,
|
|
12
|
+
messageId,
|
|
13
|
+
attachmentId,
|
|
14
|
+
],
|
|
15
|
+
queryFn: async () => {
|
|
16
|
+
if (!userAuth)
|
|
17
|
+
throw new Error("userAuth is required");
|
|
18
|
+
if (!mailboxId)
|
|
19
|
+
throw new Error("mailboxId is required");
|
|
20
|
+
if (!messageId)
|
|
21
|
+
throw new Error("messageId is required");
|
|
22
|
+
if (!attachmentId)
|
|
23
|
+
throw new Error("attachmentId is required");
|
|
24
|
+
try {
|
|
25
|
+
return await api.getMessageAttachment(userAuth, mailboxId, messageId, attachmentId);
|
|
26
|
+
}
|
|
27
|
+
catch (err) {
|
|
28
|
+
if (devMode) {
|
|
29
|
+
console.warn("[DevMode] getMessageAttachment failed, returning mock data:", err);
|
|
30
|
+
return new Blob(["Mock attachment content"], {
|
|
31
|
+
type: "text/plain",
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
throw err;
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
enabled: !!userAuth && !!mailboxId && messageId !== undefined && !!attachmentId,
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=useWildduckGetMessageAttachment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessageAttachment.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessageAttachment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAsB5D,MAAM,CAAC,MAAM,+BAA+B,GAAG,CAC7C,aAA4B,EAC5B,MAAsB,EACtB,SAAgD,EAAE,EAClD,EAAE;IACF,MAAM,EACJ,QAAQ,EACR,SAAS,EACT,SAAS,EACT,YAAY,EACZ,OAAO,GAAG,KAAK,GAChB,GAAG,MAAM,CAAC;IAEX,MAAM,GAAG,GAAG,OAAO,CACjB,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE;YACR,6BAA6B;YAC7B,QAAQ,EAAE,MAAM;YAChB,SAAS;YACT,SAAS;YACT,YAAY;SACb;QACD,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,CAAC,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;YACvD,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACzD,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACzD,IAAI,CAAC,YAAY;gBAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;YAE/D,IAAI,CAAC;gBACH,OAAO,MAAM,GAAG,CAAC,oBAAoB,CACnC,QAAQ,EACR,SAAS,EACT,SAAS,EACT,YAAY,CACb,CAAC;YACJ,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,6DAA6D,EAC7D,GAAG,CACJ,CAAC;oBACF,OAAO,IAAI,IAAI,CAAC,CAAC,yBAAyB,CAAC,EAAE;wBAC3C,IAAI,EAAE,YAAY;qBACnB,CAAC,CAAC;gBACL,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,OAAO,EACL,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS,IAAI,SAAS,KAAK,SAAS,IAAI,CAAC,CAAC,YAAY;KACzE,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
2
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
3
|
+
import type { WildduckUserAuth } from "@sudobility/types";
|
|
4
|
+
export interface UseWildduckGetMessageSourceParams {
|
|
5
|
+
userAuth?: WildduckUserAuth;
|
|
6
|
+
mailboxId?: string;
|
|
7
|
+
messageId?: number;
|
|
8
|
+
devMode?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare const useWildduckGetMessageSource: (networkClient: NetworkClient, config: WildduckConfig, params?: UseWildduckGetMessageSourceParams) => import("@tanstack/react-query").UseQueryResult<string, Error>;
|
|
11
|
+
export type UseWildduckGetMessageSourceReturn = ReturnType<typeof useWildduckGetMessageSource>;
|
|
12
|
+
//# sourceMappingURL=useWildduckGetMessageSource.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessageSource.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessageSource.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM,WAAW,iCAAiC;IAChD,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAWD,eAAO,MAAM,2BAA2B,GACtC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,SAAQ,iCAAsC,kEAoC/C,CAAC;AAEF,MAAM,MAAM,iCAAiC,GAAG,UAAU,CACxD,OAAO,2BAA2B,CACnC,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { useQuery } from "@tanstack/react-query";
|
|
3
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
4
|
+
export const useWildduckGetMessageSource = (networkClient, config, params = {}) => {
|
|
5
|
+
const { userAuth, mailboxId, messageId, devMode = false } = params;
|
|
6
|
+
const api = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
return useQuery({
|
|
8
|
+
queryKey: [
|
|
9
|
+
"wildduck-message-source",
|
|
10
|
+
userAuth?.userId,
|
|
11
|
+
mailboxId,
|
|
12
|
+
messageId,
|
|
13
|
+
],
|
|
14
|
+
queryFn: async () => {
|
|
15
|
+
if (!userAuth)
|
|
16
|
+
throw new Error("userAuth is required");
|
|
17
|
+
if (!mailboxId)
|
|
18
|
+
throw new Error("mailboxId is required");
|
|
19
|
+
if (!messageId)
|
|
20
|
+
throw new Error("messageId is required");
|
|
21
|
+
try {
|
|
22
|
+
return await api.getMessageSource(userAuth, mailboxId, messageId);
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
if (devMode) {
|
|
26
|
+
console.warn("[DevMode] getMessageSource failed, returning mock data:", err);
|
|
27
|
+
return `From: mock@example.com\nTo: user@example.com\nSubject: Mock Message\nDate: ${new Date().toISOString()}\n\nMock message body`;
|
|
28
|
+
}
|
|
29
|
+
throw err;
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
enabled: !!userAuth && !!mailboxId && messageId !== undefined,
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=useWildduckGetMessageSource.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessageSource.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessageSource.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAqB5D,MAAM,CAAC,MAAM,2BAA2B,GAAG,CACzC,aAA4B,EAC5B,MAAsB,EACtB,SAA4C,EAAE,EAC9C,EAAE;IACF,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,GAAG,KAAK,EAAE,GAAG,MAAM,CAAC;IAEnE,MAAM,GAAG,GAAG,OAAO,CACjB,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE;YACR,yBAAyB;YACzB,QAAQ,EAAE,MAAM;YAChB,SAAS;YACT,SAAS;SACV;QACD,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,CAAC,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;YACvD,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACzD,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAEzD,IAAI,CAAC;gBACH,OAAO,MAAM,GAAG,CAAC,gBAAgB,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;YACpE,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,yDAAyD,EACzD,GAAG,CACJ,CAAC;oBACF,OAAO,8EAA8E,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,uBAAuB,CAAC;gBACvI,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS,IAAI,SAAS,KAAK,SAAS;KAC9D,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
2
|
+
import { type GetMessagesRequest, type WildduckConfig } from "@sudobility/types";
|
|
3
|
+
import type { WildduckUserAuth } from "@sudobility/types";
|
|
4
|
+
export interface UseWildduckGetMessagesParams {
|
|
5
|
+
userAuth?: WildduckUserAuth;
|
|
6
|
+
mailboxId?: string;
|
|
7
|
+
options?: Omit<GetMessagesRequest, "sess" | "ip">;
|
|
8
|
+
}
|
|
9
|
+
export declare const useWildduckGetMessages: (networkClient: NetworkClient, config: WildduckConfig, params?: UseWildduckGetMessagesParams) => import("@tanstack/react-query").UseQueryResult<import("@sudobility/types").WildduckMessagesResponse, Error>;
|
|
10
|
+
export type UseWildduckGetMessagesReturn = ReturnType<typeof useWildduckGetMessages>;
|
|
11
|
+
//# sourceMappingURL=useWildduckGetMessages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessages.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessages.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EACL,KAAK,kBAAkB,EACvB,KAAK,cAAc,EACpB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM,WAAW,4BAA4B;IAC3C,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,IAAI,CAAC,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC,CAAC;CACnD;AAYD,eAAO,MAAM,sBAAsB,GACjC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,SAAQ,4BAAiC,gHAmB1C,CAAC;AAGF,MAAM,MAAM,4BAA4B,GAAG,UAAU,CACnD,OAAO,sBAAsB,CAC9B,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { useQuery } from "@tanstack/react-query";
|
|
3
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
4
|
+
export const useWildduckGetMessages = (networkClient, config, params = {}) => {
|
|
5
|
+
const { userAuth, mailboxId, options } = params;
|
|
6
|
+
const api = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
return useQuery({
|
|
8
|
+
queryKey: ["messages", userAuth?.userId, mailboxId, options],
|
|
9
|
+
queryFn: async () => {
|
|
10
|
+
if (!userAuth || !mailboxId) {
|
|
11
|
+
throw new Error("userAuth and mailboxId are required");
|
|
12
|
+
}
|
|
13
|
+
return await api.getMessages(userAuth, mailboxId, options);
|
|
14
|
+
},
|
|
15
|
+
enabled: !!userAuth && !!mailboxId,
|
|
16
|
+
});
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=useWildduckGetMessages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckGetMessages.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckGetMessages.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAwB5D,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,aAA4B,EAC5B,MAAsB,EACtB,SAAuC,EAAE,EACzC,EAAE;IACF,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;IAEhD,MAAM,GAAG,GAAG,OAAO,CACjB,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE,CAAC,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC;QAC5D,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,CAAC,QAAQ,IAAI,CAAC,SAAS,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;YACzD,CAAC;YACD,OAAO,MAAM,GAAG,CAAC,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC7D,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS;KACnC,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
2
|
+
import type { WildduckUserAuth } from "@sudobility/types";
|
|
3
|
+
export interface UseWildduckSearchMessagesParams {
|
|
4
|
+
userAuth?: WildduckUserAuth;
|
|
5
|
+
query?: string;
|
|
6
|
+
limit?: number;
|
|
7
|
+
page?: number;
|
|
8
|
+
devMode?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare const useWildduckSearchMessages: (config: WildduckConfig, params?: UseWildduckSearchMessagesParams) => import("@tanstack/react-query").UseQueryResult<unknown[], Error>;
|
|
11
|
+
export type UseWildduckSearchMessagesReturn = ReturnType<typeof useWildduckSearchMessages>;
|
|
12
|
+
//# sourceMappingURL=useWildduckSearchMessages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSearchMessages.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSearchMessages.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM,WAAW,+BAA+B;IAC9C,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAUD,eAAO,MAAM,yBAAyB,GACpC,QAAQ,cAAc,EACtB,SAAQ,+BAAoC,qEAyD7C,CAAC;AAEF,MAAM,MAAM,+BAA+B,GAAG,UAAU,CACtD,OAAO,yBAAyB,CACjC,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { useQuery } from "@tanstack/react-query";
|
|
2
|
+
import axios from "axios";
|
|
3
|
+
export const useWildduckSearchMessages = (config, params = {}) => {
|
|
4
|
+
const { userAuth, query, limit = 50, page = 1, devMode = false } = params;
|
|
5
|
+
return useQuery({
|
|
6
|
+
queryKey: [
|
|
7
|
+
"wildduck-search-messages",
|
|
8
|
+
userAuth?.userId,
|
|
9
|
+
query,
|
|
10
|
+
limit,
|
|
11
|
+
page,
|
|
12
|
+
],
|
|
13
|
+
queryFn: async () => {
|
|
14
|
+
if (!userAuth)
|
|
15
|
+
throw new Error("userAuth is required");
|
|
16
|
+
if (!query)
|
|
17
|
+
throw new Error("query is required");
|
|
18
|
+
try {
|
|
19
|
+
const apiUrl = config.cloudflareWorkerUrl || config.backendUrl;
|
|
20
|
+
const headers = {
|
|
21
|
+
"Content-Type": "application/json",
|
|
22
|
+
Accept: "application/json",
|
|
23
|
+
};
|
|
24
|
+
if (config.cloudflareWorkerUrl) {
|
|
25
|
+
headers["Authorization"] = `Bearer ${config.apiToken}`;
|
|
26
|
+
headers["X-App-Source"] = "0xmail-box";
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
headers["X-Access-Token"] = config.apiToken;
|
|
30
|
+
}
|
|
31
|
+
const response = await axios.get(`${apiUrl}/users/${userAuth.userId}/search?q=${encodeURIComponent(query)}&limit=${limit}&page=${page}`, { headers });
|
|
32
|
+
const searchResponse = response.data;
|
|
33
|
+
return searchResponse.results || [];
|
|
34
|
+
}
|
|
35
|
+
catch (err) {
|
|
36
|
+
if (devMode) {
|
|
37
|
+
console.warn("[DevMode] searchMessages failed, returning mock data:", err);
|
|
38
|
+
return [];
|
|
39
|
+
}
|
|
40
|
+
throw err;
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
enabled: !!userAuth && !!query,
|
|
44
|
+
});
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=useWildduckSearchMessages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSearchMessages.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSearchMessages.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjD,OAAO,KAAK,MAAM,OAAO,CAAC;AAmB1B,MAAM,CAAC,MAAM,yBAAyB,GAAG,CACvC,MAAsB,EACtB,SAA0C,EAAE,EAC5C,EAAE;IACF,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,GAAG,EAAE,EAAE,IAAI,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,EAAE,GAAG,MAAM,CAAC;IAE1E,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE;YACR,0BAA0B;YAC1B,QAAQ,EAAE,MAAM;YAChB,KAAK;YACL,KAAK;YACL,IAAI;SACL;QACD,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,CAAC,QAAQ;gBAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;YACvD,IAAI,CAAC,KAAK;gBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAEjD,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,UAAU,CAAC;gBAG/D,MAAM,OAAO,GAA2B;oBACtC,cAAc,EAAE,kBAAkB;oBAClC,MAAM,EAAE,kBAAkB;iBAC3B,CAAC;gBAEF,IAAI,MAAM,CAAC,mBAAmB,EAAE,CAAC;oBAC/B,OAAO,CAAC,eAAe,CAAC,GAAG,UAAU,MAAM,CAAC,QAAQ,EAAE,CAAC;oBACvD,OAAO,CAAC,cAAc,CAAC,GAAG,YAAY,CAAC;gBACzC,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,gBAAgB,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC;gBAC9C,CAAC;gBAED,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAC9B,GAAG,MAAM,UAAU,QAAQ,CAAC,MAAM,aAAa,kBAAkB,CAAC,KAAK,CAAC,UAAU,KAAK,SAAS,IAAI,EAAE,EACtG,EAAE,OAAO,EAAE,CACZ,CAAC;gBAEF,MAAM,cAAc,GAAG,QAAQ,CAAC,IAI/B,CAAC;gBAEF,OAAO,cAAc,CAAC,OAAO,IAAI,EAAE,CAAC;YACtC,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,uDAAuD,EACvD,GAAG,CACJ,CAAC;oBACF,OAAO,EAAE,CAAC;gBACZ,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,KAAK;KAC/B,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Optional } from "@sudobility/types";
|
|
2
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
3
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
4
|
+
import type { WildduckSubmitMessageRequest, WildduckSubmitMessageResponse, WildduckUserAuth } from "@sudobility/types";
|
|
5
|
+
interface UseWildduckSendMessageReturn {
|
|
6
|
+
sendMessage: (userAuth: WildduckUserAuth, params: WildduckSubmitMessageRequest) => Promise<WildduckSubmitMessageResponse>;
|
|
7
|
+
isLoading: boolean;
|
|
8
|
+
error: Optional<Error>;
|
|
9
|
+
clearError: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare const useWildduckSendMessage: (networkClient: NetworkClient, config: WildduckConfig, devMode?: boolean) => UseWildduckSendMessageReturn;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=useWildduckSendMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSendMessage.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSendMessage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAGlD,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,KAAK,EACV,4BAA4B,EAC5B,6BAA6B,EAC7B,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAE3B,UAAU,4BAA4B;IACpC,WAAW,EAAE,CACX,QAAQ,EAAE,gBAAgB,EAC1B,MAAM,EAAE,4BAA4B,KACjC,OAAO,CAAC,6BAA6B,CAAC,CAAC;IAC5C,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAYD,eAAO,MAAM,sBAAsB,GACjC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,UAAS,OAAe,KACvB,4BAqEF,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { useCallback, useMemo } from "react";
|
|
2
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
3
|
+
import { useMutation, useQueryClient } from "@tanstack/react-query";
|
|
4
|
+
export const useWildduckSendMessage = (networkClient, config, devMode = false) => {
|
|
5
|
+
const queryClient = useQueryClient();
|
|
6
|
+
const wildduckClient = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
const sendMutation = useMutation({
|
|
8
|
+
mutationKey: [
|
|
9
|
+
"wildduck-send-message",
|
|
10
|
+
config.cloudflareWorkerUrl || config.backendUrl,
|
|
11
|
+
],
|
|
12
|
+
mutationFn: async ({ userAuth, params, }) => {
|
|
13
|
+
try {
|
|
14
|
+
return await wildduckClient.submitMessage(userAuth, params);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
if (devMode) {
|
|
18
|
+
console.warn("[DevMode] sendMessage failed, returning mock data:", err);
|
|
19
|
+
return {
|
|
20
|
+
success: true,
|
|
21
|
+
message: {
|
|
22
|
+
id: `mock-message-${Date.now()}`,
|
|
23
|
+
from: "mock@example.com",
|
|
24
|
+
to: ["recipient@example.com"],
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
throw err;
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
onSuccess: (_, variables) => {
|
|
32
|
+
queryClient.invalidateQueries({
|
|
33
|
+
queryKey: ["wildduck-messages", variables.userAuth.userId],
|
|
34
|
+
});
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
const sendMessage = useCallback(async (userAuth, params) => {
|
|
38
|
+
return sendMutation.mutateAsync({ userAuth, params });
|
|
39
|
+
}, [sendMutation]);
|
|
40
|
+
const clearError = useCallback(() => sendMutation.reset(), [sendMutation]);
|
|
41
|
+
return useMemo(() => ({
|
|
42
|
+
sendMessage,
|
|
43
|
+
isLoading: sendMutation.isPending,
|
|
44
|
+
error: sendMutation.error,
|
|
45
|
+
clearError,
|
|
46
|
+
}), [sendMessage, sendMutation.isPending, sendMutation.error, clearError]);
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=useWildduckSendMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSendMessage.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSendMessage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAG5D,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AA2BpE,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,aAA4B,EAC5B,MAAsB,EACtB,UAAmB,KAAK,EACM,EAAE;IAChC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,MAAM,YAAY,GAAG,WAAW,CAAC;QAC/B,WAAW,EAAE;YACX,uBAAuB;YACvB,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,UAAU;SAChD;QACD,UAAU,EAAE,KAAK,EAAE,EACjB,QAAQ,EACR,MAAM,GAIP,EAA0C,EAAE;YAC3C,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC9D,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,oDAAoD,EACpD,GAAG,CACJ,CAAC;oBACF,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,OAAO,EAAE;4BACP,EAAE,EAAE,gBAAgB,IAAI,CAAC,GAAG,EAAE,EAAE;4BAChC,IAAI,EAAE,kBAAkB;4BACxB,EAAE,EAAE,CAAC,uBAAuB,CAAC;yBAC9B;qBAC+B,CAAC;gBACrC,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE;YAE1B,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE,CAAC,mBAAmB,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;aAC3D,CAAC,CAAC;QACL,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,WAAW,CAC7B,KAAK,EACH,QAA0B,EAC1B,MAAoC,EACpC,EAAE;QACF,OAAO,YAAY,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;IACxD,CAAC,EACD,CAAC,YAAY,CAAC,CACf,CAAC;IAEF,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAE3E,OAAO,OAAO,CACZ,GAAG,EAAE,CAAC,CAAC;QACL,WAAW;QACX,SAAS,EAAE,YAAY,CAAC,SAAS;QACjC,KAAK,EAAE,YAAY,CAAC,KAAK;QACzB,UAAU;KACX,CAAC,EACF,CAAC,WAAW,EAAE,YAAY,CAAC,SAAS,EAAE,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CACtE,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Optional } from "@sudobility/types";
|
|
2
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
3
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
4
|
+
import type { WildduckSuccessResponse, WildduckUserAuth } from "@sudobility/types";
|
|
5
|
+
interface UseWildduckSubmitDraftReturn {
|
|
6
|
+
submitDraft: (userAuth: WildduckUserAuth, mailboxId: string, messageId: number) => Promise<WildduckSuccessResponse>;
|
|
7
|
+
isLoading: boolean;
|
|
8
|
+
error: Optional<Error>;
|
|
9
|
+
clearError: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare const useWildduckSubmitDraft: (networkClient: NetworkClient, config: WildduckConfig, devMode?: boolean) => UseWildduckSubmitDraftReturn;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=useWildduckSubmitDraft.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSubmitDraft.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSubmitDraft.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAGlD,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,KAAK,EACV,uBAAuB,EACvB,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAE3B,UAAU,4BAA4B;IACpC,WAAW,EAAE,CACX,QAAQ,EAAE,gBAAgB,EAC1B,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,KACd,OAAO,CAAC,uBAAuB,CAAC,CAAC;IACtC,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAYD,eAAO,MAAM,sBAAsB,GACjC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,UAAS,OAAe,KACvB,4BAuEF,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { useCallback, useMemo } from "react";
|
|
2
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
3
|
+
import { useMutation, useQueryClient } from "@tanstack/react-query";
|
|
4
|
+
export const useWildduckSubmitDraft = (networkClient, config, devMode = false) => {
|
|
5
|
+
const queryClient = useQueryClient();
|
|
6
|
+
const wildduckClient = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
const submitMutation = useMutation({
|
|
8
|
+
mutationKey: [
|
|
9
|
+
"wildduck-submit-draft",
|
|
10
|
+
config.cloudflareWorkerUrl || config.backendUrl,
|
|
11
|
+
],
|
|
12
|
+
mutationFn: async ({ userAuth, mailboxId, messageId, }) => {
|
|
13
|
+
try {
|
|
14
|
+
return await wildduckClient.submitDraft(userAuth, mailboxId, messageId);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
if (devMode) {
|
|
18
|
+
console.warn("[DevMode] submitDraft failed, returning mock data:", err);
|
|
19
|
+
return { success: true };
|
|
20
|
+
}
|
|
21
|
+
throw err;
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
onSuccess: (_, variables) => {
|
|
25
|
+
queryClient.invalidateQueries({
|
|
26
|
+
queryKey: ["wildduck-messages", variables.userAuth.userId],
|
|
27
|
+
});
|
|
28
|
+
queryClient.invalidateQueries({
|
|
29
|
+
queryKey: ["wildduck-mailboxes", variables.userAuth.userId],
|
|
30
|
+
});
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
const submitDraft = useCallback(async (userAuth, mailboxId, messageId) => {
|
|
34
|
+
return submitMutation.mutateAsync({ userAuth, mailboxId, messageId });
|
|
35
|
+
}, [submitMutation]);
|
|
36
|
+
const clearError = useCallback(() => submitMutation.reset(), [submitMutation]);
|
|
37
|
+
return useMemo(() => ({
|
|
38
|
+
submitDraft,
|
|
39
|
+
isLoading: submitMutation.isPending,
|
|
40
|
+
error: submitMutation.error,
|
|
41
|
+
clearError,
|
|
42
|
+
}), [submitDraft, submitMutation.isPending, submitMutation.error, clearError]);
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=useWildduckSubmitDraft.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckSubmitDraft.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckSubmitDraft.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAG5D,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AA2BpE,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,aAA4B,EAC5B,MAAsB,EACtB,UAAmB,KAAK,EACM,EAAE;IAChC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,MAAM,cAAc,GAAG,WAAW,CAAC;QACjC,WAAW,EAAE;YACX,uBAAuB;YACvB,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,UAAU;SAChD;QACD,UAAU,EAAE,KAAK,EAAE,EACjB,QAAQ,EACR,SAAS,EACT,SAAS,GAKV,EAAoC,EAAE;YACrC,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;YAC1E,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,oDAAoD,EACpD,GAAG,CACJ,CAAC;oBACF,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBAC3B,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE;YAE1B,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE,CAAC,mBAAmB,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;aAC3D,CAAC,CAAC;YACH,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE,CAAC,oBAAoB,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;aAC5D,CAAC,CAAC;QACL,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,WAAW,CAC7B,KAAK,EACH,QAA0B,EAC1B,SAAiB,EACjB,SAAiB,EACjB,EAAE;QACF,OAAO,cAAc,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;IACxE,CAAC,EACD,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,MAAM,UAAU,GAAG,WAAW,CAC5B,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,EAC5B,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,OAAO,OAAO,CACZ,GAAG,EAAE,CAAC,CAAC;QACL,WAAW;QACX,SAAS,EAAE,cAAc,CAAC,SAAS;QACnC,KAAK,EAAE,cAAc,CAAC,KAAK;QAC3B,UAAU;KACX,CAAC,EACF,CAAC,WAAW,EAAE,cAAc,CAAC,SAAS,EAAE,cAAc,CAAC,KAAK,EAAE,UAAU,CAAC,CAC1E,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Optional } from "@sudobility/types";
|
|
2
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
3
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
4
|
+
import type { WildduckUpdateMessageRequest, WildduckUpdateMessageResponse, WildduckUserAuth } from "@sudobility/types";
|
|
5
|
+
interface UseWildduckUpdateMessageReturn {
|
|
6
|
+
updateMessage: (userAuth: WildduckUserAuth, mailboxId: string, messageId: number, params: WildduckUpdateMessageRequest) => Promise<WildduckUpdateMessageResponse>;
|
|
7
|
+
isLoading: boolean;
|
|
8
|
+
error: Optional<Error>;
|
|
9
|
+
clearError: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare const useWildduckUpdateMessage: (networkClient: NetworkClient, config: WildduckConfig, devMode?: boolean) => UseWildduckUpdateMessageReturn;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=useWildduckUpdateMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckUpdateMessage.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckUpdateMessage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAGlD,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,KAAK,EACV,4BAA4B,EAC5B,6BAA6B,EAC7B,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAE3B,UAAU,8BAA8B;IACtC,aAAa,EAAE,CACb,QAAQ,EAAE,gBAAgB,EAC1B,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,4BAA4B,KACjC,OAAO,CAAC,6BAA6B,CAAC,CAAC;IAC5C,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAYD,eAAO,MAAM,wBAAwB,GACnC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,UAAS,OAAe,KACvB,8BAwFF,CAAC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { useCallback, useMemo } from "react";
|
|
2
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
3
|
+
import { useMutation, useQueryClient } from "@tanstack/react-query";
|
|
4
|
+
export const useWildduckUpdateMessage = (networkClient, config, devMode = false) => {
|
|
5
|
+
const queryClient = useQueryClient();
|
|
6
|
+
const wildduckClient = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
const updateMutation = useMutation({
|
|
8
|
+
mutationKey: [
|
|
9
|
+
"wildduck-update-message",
|
|
10
|
+
config.cloudflareWorkerUrl || config.backendUrl,
|
|
11
|
+
],
|
|
12
|
+
mutationFn: async ({ userAuth, mailboxId, messageId, params, }) => {
|
|
13
|
+
try {
|
|
14
|
+
return await wildduckClient.updateMessage(userAuth, mailboxId, messageId, params);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
if (devMode) {
|
|
18
|
+
console.warn("[DevMode] updateMessage failed, returning mock data:", err);
|
|
19
|
+
return { success: true };
|
|
20
|
+
}
|
|
21
|
+
throw err;
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
onSuccess: (_, variables) => {
|
|
25
|
+
queryClient.invalidateQueries({
|
|
26
|
+
queryKey: [
|
|
27
|
+
"wildduck-message",
|
|
28
|
+
variables.userAuth.userId,
|
|
29
|
+
variables.messageId,
|
|
30
|
+
],
|
|
31
|
+
});
|
|
32
|
+
queryClient.invalidateQueries({
|
|
33
|
+
queryKey: ["wildduck-messages", variables.userAuth.userId],
|
|
34
|
+
});
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
const updateMessage = useCallback(async (userAuth, mailboxId, messageId, params) => {
|
|
38
|
+
return updateMutation.mutateAsync({
|
|
39
|
+
userAuth,
|
|
40
|
+
mailboxId,
|
|
41
|
+
messageId,
|
|
42
|
+
params,
|
|
43
|
+
});
|
|
44
|
+
}, [updateMutation]);
|
|
45
|
+
const clearError = useCallback(() => updateMutation.reset(), [updateMutation]);
|
|
46
|
+
return useMemo(() => ({
|
|
47
|
+
updateMessage,
|
|
48
|
+
isLoading: updateMutation.isPending,
|
|
49
|
+
error: updateMutation.error,
|
|
50
|
+
clearError,
|
|
51
|
+
}), [updateMessage, updateMutation.isPending, updateMutation.error, clearError]);
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=useWildduckUpdateMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckUpdateMessage.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckUpdateMessage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAG5D,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AA6BpE,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,aAA4B,EAC5B,MAAsB,EACtB,UAAmB,KAAK,EACQ,EAAE;IAClC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,MAAM,cAAc,GAAG,WAAW,CAAC;QACjC,WAAW,EAAE;YACX,yBAAyB;YACzB,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,UAAU;SAChD;QACD,UAAU,EAAE,KAAK,EAAE,EACjB,QAAQ,EACR,SAAS,EACT,SAAS,EACT,MAAM,GAMP,EAA0C,EAAE;YAC3C,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,aAAa,CACvC,QAAQ,EACR,SAAS,EACT,SAAS,EACT,MAAM,CACP,CAAC;YACJ,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,sDAAsD,EACtD,GAAG,CACJ,CAAC;oBACF,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBAC3B,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE;YAE1B,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE;oBACR,kBAAkB;oBAClB,SAAS,CAAC,QAAQ,CAAC,MAAM;oBACzB,SAAS,CAAC,SAAS;iBACpB;aACF,CAAC,CAAC;YACH,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE,CAAC,mBAAmB,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;aAC3D,CAAC,CAAC;QACL,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,WAAW,CAC/B,KAAK,EACH,QAA0B,EAC1B,SAAiB,EACjB,SAAiB,EACjB,MAAoC,EACpC,EAAE;QACF,OAAO,cAAc,CAAC,WAAW,CAAC;YAChC,QAAQ;YACR,SAAS;YACT,SAAS;YACT,MAAM;SACP,CAAC,CAAC;IACL,CAAC,EACD,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,MAAM,UAAU,GAAG,WAAW,CAC5B,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,EAC5B,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,OAAO,OAAO,CACZ,GAAG,EAAE,CAAC,CAAC;QACL,aAAa;QACb,SAAS,EAAE,cAAc,CAAC,SAAS;QACnC,KAAK,EAAE,cAAc,CAAC,KAAK;QAC3B,UAAU;KACX,CAAC,EACF,CAAC,aAAa,EAAE,cAAc,CAAC,SAAS,EAAE,cAAc,CAAC,KAAK,EAAE,UAAU,CAAC,CAC5E,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Optional } from "@sudobility/types";
|
|
2
|
+
import { type NetworkClient } from "@sudobility/di";
|
|
3
|
+
import { type WildduckConfig } from "@sudobility/types";
|
|
4
|
+
import type { WildduckUploadMessageRequest, WildduckUploadMessageResponse, WildduckUserAuth } from "@sudobility/types";
|
|
5
|
+
interface UseWildduckUploadMessageReturn {
|
|
6
|
+
uploadMessage: (userAuth: WildduckUserAuth, mailboxId: string, params: WildduckUploadMessageRequest) => Promise<WildduckUploadMessageResponse>;
|
|
7
|
+
isLoading: boolean;
|
|
8
|
+
error: Optional<Error>;
|
|
9
|
+
clearError: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare const useWildduckUploadMessage: (networkClient: NetworkClient, config: WildduckConfig, devMode?: boolean) => UseWildduckUploadMessageReturn;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=useWildduckUploadMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckUploadMessage.d.ts","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckUploadMessage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAGlD,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,KAAK,EACV,4BAA4B,EAC5B,6BAA6B,EAC7B,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAE3B,UAAU,8BAA8B;IACtC,aAAa,EAAE,CACb,QAAQ,EAAE,gBAAgB,EAC1B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,4BAA4B,KACjC,OAAO,CAAC,6BAA6B,CAAC,CAAC;IAC5C,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAaD,eAAO,MAAM,wBAAwB,GACnC,eAAe,aAAa,EAC5B,QAAQ,cAAc,EACtB,UAAS,OAAe,KACvB,8BA8EF,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { useCallback, useMemo } from "react";
|
|
2
|
+
import { WildduckAPI } from "../../network/wildduck-client";
|
|
3
|
+
import { useMutation, useQueryClient } from "@tanstack/react-query";
|
|
4
|
+
export const useWildduckUploadMessage = (networkClient, config, devMode = false) => {
|
|
5
|
+
const queryClient = useQueryClient();
|
|
6
|
+
const wildduckClient = useMemo(() => new WildduckAPI(networkClient, config), [networkClient, config]);
|
|
7
|
+
const uploadMutation = useMutation({
|
|
8
|
+
mutationKey: [
|
|
9
|
+
"wildduck-upload-message",
|
|
10
|
+
config.cloudflareWorkerUrl || config.backendUrl,
|
|
11
|
+
],
|
|
12
|
+
mutationFn: async ({ userAuth, mailboxId, params, }) => {
|
|
13
|
+
try {
|
|
14
|
+
return await wildduckClient.uploadMessage(userAuth, mailboxId, params);
|
|
15
|
+
}
|
|
16
|
+
catch (err) {
|
|
17
|
+
if (devMode) {
|
|
18
|
+
console.warn("[DevMode] uploadMessage failed, returning mock data:", err);
|
|
19
|
+
return {
|
|
20
|
+
success: true,
|
|
21
|
+
message: { id: Date.now(), mailbox: mailboxId },
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
throw err;
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
onSuccess: (_, variables) => {
|
|
28
|
+
queryClient.invalidateQueries({
|
|
29
|
+
queryKey: [
|
|
30
|
+
"wildduck-messages",
|
|
31
|
+
variables.userAuth.userId,
|
|
32
|
+
variables.mailboxId,
|
|
33
|
+
],
|
|
34
|
+
});
|
|
35
|
+
queryClient.invalidateQueries({
|
|
36
|
+
queryKey: ["wildduck-mailboxes", variables.userAuth.userId],
|
|
37
|
+
});
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
const uploadMessage = useCallback(async (userAuth, mailboxId, params) => {
|
|
41
|
+
return uploadMutation.mutateAsync({ userAuth, mailboxId, params });
|
|
42
|
+
}, [uploadMutation]);
|
|
43
|
+
const clearError = useCallback(() => uploadMutation.reset(), [uploadMutation]);
|
|
44
|
+
return useMemo(() => ({
|
|
45
|
+
uploadMessage,
|
|
46
|
+
isLoading: uploadMutation.isPending,
|
|
47
|
+
error: uploadMutation.error,
|
|
48
|
+
clearError,
|
|
49
|
+
}), [uploadMessage, uploadMutation.isPending, uploadMutation.error, clearError]);
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=useWildduckUploadMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWildduckUploadMessage.js","sourceRoot":"","sources":["../../../src/hooks/messages/useWildduckUploadMessage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAG5D,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AA6BpE,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,aAA4B,EAC5B,MAAsB,EACtB,UAAmB,KAAK,EACQ,EAAE;IAClC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,EAC5C,CAAC,aAAa,EAAE,MAAM,CAAC,CACxB,CAAC;IAEF,MAAM,cAAc,GAAG,WAAW,CAAC;QACjC,WAAW,EAAE;YACX,yBAAyB;YACzB,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,UAAU;SAChD;QACD,UAAU,EAAE,KAAK,EAAE,EACjB,QAAQ,EACR,SAAS,EACT,MAAM,GAKP,EAA0C,EAAE;YAC3C,IAAI,CAAC;gBACH,OAAO,MAAM,cAAc,CAAC,aAAa,CAAC,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;YACzE,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,IAAI,CACV,sDAAsD,EACtD,GAAG,CACJ,CAAC;oBACF,OAAO;wBACL,OAAO,EAAE,IAAI;wBACb,OAAO,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE;qBACf,CAAC;gBACrC,CAAC;gBACD,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE;YAE1B,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE;oBACR,mBAAmB;oBACnB,SAAS,CAAC,QAAQ,CAAC,MAAM;oBACzB,SAAS,CAAC,SAAS;iBACpB;aACF,CAAC,CAAC;YACH,WAAW,CAAC,iBAAiB,CAAC;gBAC5B,QAAQ,EAAE,CAAC,oBAAoB,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;aAC5D,CAAC,CAAC;QACL,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,WAAW,CAC/B,KAAK,EACH,QAA0B,EAC1B,SAAiB,EACjB,MAAoC,EACpC,EAAE;QACF,OAAO,cAAc,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;IACrE,CAAC,EACD,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,MAAM,UAAU,GAAG,WAAW,CAC5B,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,EAC5B,CAAC,cAAc,CAAC,CACjB,CAAC;IAEF,OAAO,OAAO,CACZ,GAAG,EAAE,CAAC,CAAC;QACL,aAAa;QACb,SAAS,EAAE,cAAc,CAAC,SAAS;QACnC,KAAK,EAAE,cAAc,CAAC,KAAK;QAC3B,UAAU;KACX,CAAC,EACF,CAAC,aAAa,EAAE,cAAc,CAAC,SAAS,EAAE,cAAc,CAAC,KAAK,EAAE,UAAU,CAAC,CAC5E,CAAC;AACJ,CAAC,CAAC"}
|