@webiny/app-mailer 0.0.0-unstable.6f45466a1d → 0.0.0-unstable.7be00a75a9
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/Module.js +30 -48
- package/Module.js.map +1 -1
- package/hooks/usePermission.js +12 -12
- package/hooks/usePermission.js.map +1 -1
- package/index.js +0 -2
- package/package.json +21 -18
- package/routes.js +6 -5
- package/routes.js.map +1 -1
- package/types.d.ts +1 -0
- package/types.js +0 -3
- package/views/settings/Settings.js +194 -173
- package/views/settings/Settings.js.map +1 -1
- package/views/settings/graphql.d.ts +8 -5
- package/views/settings/graphql.js +5 -3
- package/views/settings/graphql.js.map +1 -1
- package/views/settings/index.js +2 -1
- package/views/settings/index.js.map +1 -1
- package/index.js.map +0 -1
- package/types.js.map +0 -1
package/Module.js
CHANGED
|
@@ -1,54 +1,36 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { AdminConfig,
|
|
3
|
-
import { HasPermission } from "@webiny/app-admin";
|
|
1
|
+
import react, { Suspense, lazy } from "react";
|
|
2
|
+
import { AdminConfig, AdminLayout, HasPermission, Plugins, useRouter } from "@webiny/app-admin";
|
|
4
3
|
import { OverlayLoader } from "@webiny/admin-ui";
|
|
5
4
|
import { usePermission } from "./hooks/usePermission.js";
|
|
6
5
|
import { Routes } from "./routes.js";
|
|
7
|
-
const {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}, /*#__PURE__*/React.createElement(Loader, null, /*#__PURE__*/React.createElement(Settings, null)))
|
|
34
|
-
}), /*#__PURE__*/React.createElement(Menu, {
|
|
35
|
-
name: "mailer.settings",
|
|
36
|
-
parent: "settings",
|
|
37
|
-
element: /*#__PURE__*/React.createElement(Menu.Group, {
|
|
38
|
-
text: "Mailer"
|
|
39
|
-
})
|
|
40
|
-
}), /*#__PURE__*/React.createElement(Menu, {
|
|
41
|
-
name: "mailer.settings.general",
|
|
42
|
-
parent: "settings",
|
|
43
|
-
element: /*#__PURE__*/React.createElement(Menu.Link, {
|
|
44
|
-
text: "Settings",
|
|
45
|
-
to: router.getLink(Routes.Settings),
|
|
46
|
-
pinnable: true
|
|
47
|
-
})
|
|
48
|
-
})));
|
|
49
|
-
};
|
|
50
|
-
export const Module = () => {
|
|
51
|
-
return /*#__PURE__*/React.createElement(Plugins, null, /*#__PURE__*/React.createElement(MailerSettings, null));
|
|
6
|
+
const { Menu: Menu, Route: Route } = AdminConfig;
|
|
7
|
+
const Settings = /*#__PURE__*/ lazy(()=>import("./views/settings/index.js"));
|
|
8
|
+
const Loader = ({ children, ...props })=>/*#__PURE__*/ react.createElement(Suspense, {
|
|
9
|
+
fallback: /*#__PURE__*/ react.createElement(OverlayLoader, null)
|
|
10
|
+
}, /*#__PURE__*/ react.cloneElement(children, props));
|
|
11
|
+
const MailerSettings = ()=>{
|
|
12
|
+
const router = useRouter();
|
|
13
|
+
const { canChangeSettings } = usePermission();
|
|
14
|
+
const changeSettings = canChangeSettings();
|
|
15
|
+
if (!changeSettings) return null;
|
|
16
|
+
return /*#__PURE__*/ react.createElement(AdminConfig, null, /*#__PURE__*/ react.createElement(HasPermission, {
|
|
17
|
+
name: "mailer.settings"
|
|
18
|
+
}, /*#__PURE__*/ react.createElement(Route, {
|
|
19
|
+
route: Routes.Settings,
|
|
20
|
+
element: /*#__PURE__*/ react.createElement(AdminLayout, {
|
|
21
|
+
title: "Mailer - Settings"
|
|
22
|
+
}, /*#__PURE__*/ react.createElement(Loader, null, /*#__PURE__*/ react.createElement(Settings, null)))
|
|
23
|
+
}), /*#__PURE__*/ react.createElement(Menu, {
|
|
24
|
+
name: "mailer.settings",
|
|
25
|
+
parent: "settings.system",
|
|
26
|
+
element: /*#__PURE__*/ react.createElement(Menu.Link, {
|
|
27
|
+
text: "Mailer",
|
|
28
|
+
to: router.getLink(Routes.Settings),
|
|
29
|
+
pinnable: true
|
|
30
|
+
})
|
|
31
|
+
})));
|
|
52
32
|
};
|
|
33
|
+
const Module = ()=>/*#__PURE__*/ react.createElement(Plugins, null, /*#__PURE__*/ react.createElement(MailerSettings, null));
|
|
34
|
+
export { Module };
|
|
53
35
|
|
|
54
36
|
//# sourceMappingURL=Module.js.map
|
package/Module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"Module.js","sources":["../src/Module.tsx"],"sourcesContent":["import React, { lazy, Suspense } from \"react\";\nimport { AdminConfig, Plugins, AdminLayout, useRouter } from \"@webiny/app-admin\";\nimport { HasPermission } from \"@webiny/app-admin\";\nimport { OverlayLoader } from \"@webiny/admin-ui\";\nimport { usePermission } from \"~/hooks/usePermission.js\";\nimport { Routes } from \"~/routes.js\";\n\nconst { Menu, Route } = AdminConfig;\n\nconst Settings = lazy(\n () =>\n import(\n /* webpackChunkName: \"mailer-settings\" */\n \"~/views/settings/index.js\"\n )\n);\n\ninterface LoaderProps {\n children: React.ReactElement;\n}\n\nconst Loader = ({ children, ...props }: LoaderProps) => (\n <Suspense fallback={<OverlayLoader />}>{React.cloneElement(children, props)}</Suspense>\n);\n\nconst MailerSettings = () => {\n const router = useRouter();\n const { canChangeSettings } = usePermission();\n\n const changeSettings = canChangeSettings();\n\n if (!changeSettings) {\n return null;\n }\n\n return (\n <AdminConfig>\n <HasPermission name={\"mailer.settings\"}>\n <Route\n route={Routes.Settings}\n element={\n <AdminLayout title={\"Mailer - Settings\"}>\n <Loader>\n <Settings />\n </Loader>\n </AdminLayout>\n }\n />\n <Menu\n name={\"mailer.settings\"}\n parent={\"settings.system\"}\n element={\n <Menu.Link\n text={\"Mailer\"}\n to={router.getLink(Routes.Settings)}\n pinnable={true}\n />\n }\n />\n </HasPermission>\n </AdminConfig>\n );\n};\n\nexport const Module = () => {\n return (\n <Plugins>\n <MailerSettings />\n </Plugins>\n );\n};\n"],"names":["Menu","Route","AdminConfig","Settings","lazy","Loader","children","props","Suspense","OverlayLoader","React","MailerSettings","router","useRouter","canChangeSettings","usePermission","changeSettings","HasPermission","Routes","AdminLayout","Module","Plugins"],"mappings":";;;;;AAOA,MAAM,EAAEA,MAAAA,IAAI,EAAEC,OAAAA,KAAK,EAAE,GAAGC;AAExB,MAAMC,WAAW,WAAHA,GAAGC,KACb,IACI,MAAM,CAAN;AAUR,MAAMC,SAAS,CAAC,EAAEC,QAAQ,EAAE,GAAGC,OAAoB,iBAC/C,oBAACC,UAAQA;QAAC,wBAAU,oBAACC,eAAaA;qBAAMC,MAAAA,YAAkB,CAACJ,UAAUC;AAGzE,MAAMI,iBAAiB;IACnB,MAAMC,SAASC;IACf,MAAM,EAAEC,iBAAiB,EAAE,GAAGC;IAE9B,MAAMC,iBAAiBF;IAEvB,IAAI,CAACE,gBACD,OAAO;IAGX,OAAO,WAAP,GACI,oBAACd,aAAWA,MAAAA,WAAAA,GACR,oBAACe,eAAaA;QAAC,MAAM;qBACjB,oBAAChB,OAAKA;QACF,OAAOiB,OAAO,QAAQ;QACtB,uBACI,oBAACC,aAAWA;YAAC,OAAO;yBAChB,oBAACd,QAAMA,MAAAA,WAAAA,GACH,oBAACF,UAAQA;sBAKzB,oBAACH,MAAIA;QACD,MAAM;QACN,QAAQ;QACR,uBACI,oBAACA,KAAK,IAAI;YACN,MAAM;YACN,IAAIY,OAAO,OAAO,CAACM,OAAO,QAAQ;YAClC,UAAU;;;AAOtC;AAEO,MAAME,SAAS,IACX,WAAP,GACI,oBAACC,SAAOA,MAAAA,WAAAA,GACJ,oBAACV,gBAAcA"}
|
package/hooks/usePermission.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { useSecurity } from "@webiny/app-admin";
|
|
2
2
|
import { useCallback } from "react";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
};
|
|
3
|
+
const usePermission = ()=>{
|
|
4
|
+
const { identity, getPermission } = useSecurity();
|
|
5
|
+
const canChangeSettings = useCallback(()=>{
|
|
6
|
+
const permission = getPermission("mailer.settings");
|
|
7
|
+
return !!permission;
|
|
8
|
+
}, [
|
|
9
|
+
identity
|
|
10
|
+
]);
|
|
11
|
+
return {
|
|
12
|
+
canChangeSettings
|
|
13
|
+
};
|
|
15
14
|
};
|
|
15
|
+
export { usePermission };
|
|
16
16
|
|
|
17
17
|
//# sourceMappingURL=usePermission.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"hooks/usePermission.js","sources":["../../src/hooks/usePermission.ts"],"sourcesContent":["import { useSecurity } from \"@webiny/app-admin\";\nimport { useCallback } from \"react\";\nimport type { MailerSecurityPermission } from \"~/types.js\";\n\nexport const usePermission = () => {\n const { identity, getPermission } = useSecurity();\n\n const canChangeSettings = useCallback((): boolean => {\n const permission = getPermission<MailerSecurityPermission>(\"mailer.settings\");\n return !!permission;\n }, [identity]);\n\n return {\n canChangeSettings\n };\n};\n"],"names":["usePermission","identity","getPermission","useSecurity","canChangeSettings","useCallback","permission"],"mappings":";;AAIO,MAAMA,gBAAgB;IACzB,MAAM,EAAEC,QAAQ,EAAEC,aAAa,EAAE,GAAGC;IAEpC,MAAMC,oBAAoBC,YAAY;QAClC,MAAMC,aAAaJ,cAAwC;QAC3D,OAAO,CAAC,CAACI;IACb,GAAG;QAACL;KAAS;IAEb,OAAO;QACHG;IACJ;AACJ"}
|
package/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/app-mailer",
|
|
3
|
-
"version": "0.0.0-unstable.
|
|
3
|
+
"version": "0.0.0-unstable.7be00a75a9",
|
|
4
4
|
"type": "module",
|
|
5
|
-
"
|
|
5
|
+
"exports": {
|
|
6
|
+
".": "./index.js",
|
|
7
|
+
"./*": "./*"
|
|
8
|
+
},
|
|
6
9
|
"repository": {
|
|
7
10
|
"type": "git",
|
|
8
11
|
"url": "https://github.com/webiny/webiny-js.git"
|
|
@@ -11,35 +14,35 @@
|
|
|
11
14
|
"license": "MIT",
|
|
12
15
|
"dependencies": {
|
|
13
16
|
"@apollo/react-components": "3.1.5",
|
|
14
|
-
"@webiny/admin-ui": "0.0.0-unstable.
|
|
15
|
-
"@webiny/app-admin": "0.0.0-unstable.
|
|
16
|
-
"@webiny/form": "0.0.0-unstable.
|
|
17
|
-
"@webiny/validation": "0.0.0-unstable.
|
|
17
|
+
"@webiny/admin-ui": "0.0.0-unstable.7be00a75a9",
|
|
18
|
+
"@webiny/app-admin": "0.0.0-unstable.7be00a75a9",
|
|
19
|
+
"@webiny/form": "0.0.0-unstable.7be00a75a9",
|
|
20
|
+
"@webiny/validation": "0.0.0-unstable.7be00a75a9",
|
|
18
21
|
"apollo-cache": "1.3.5",
|
|
19
22
|
"apollo-client": "2.6.10",
|
|
20
23
|
"apollo-link": "1.2.14",
|
|
21
24
|
"apollo-utilities": "1.3.4",
|
|
22
|
-
"
|
|
23
|
-
"graphql": "16.12.0",
|
|
25
|
+
"graphql": "16.14.0",
|
|
24
26
|
"graphql-tag": "2.12.6",
|
|
25
|
-
"
|
|
26
|
-
"react": "18.
|
|
27
|
-
"react-dom": "18.2.0"
|
|
27
|
+
"react": "18.3.1",
|
|
28
|
+
"react-dom": "18.3.1"
|
|
28
29
|
},
|
|
29
30
|
"devDependencies": {
|
|
30
|
-
"@types/react": "18.
|
|
31
|
-
"@webiny/build-tools": "0.0.0-unstable.
|
|
32
|
-
"rimraf": "6.1.
|
|
33
|
-
"typescript": "
|
|
31
|
+
"@types/react": "18.3.29",
|
|
32
|
+
"@webiny/build-tools": "0.0.0-unstable.7be00a75a9",
|
|
33
|
+
"rimraf": "6.1.3",
|
|
34
|
+
"typescript": "6.0.3"
|
|
34
35
|
},
|
|
35
36
|
"publishConfig": {
|
|
36
|
-
"access": "public"
|
|
37
|
-
"directory": "dist"
|
|
37
|
+
"access": "public"
|
|
38
38
|
},
|
|
39
39
|
"svgo": {
|
|
40
40
|
"plugins": {
|
|
41
41
|
"removeViewBox": false
|
|
42
42
|
}
|
|
43
43
|
},
|
|
44
|
-
"gitHead": "
|
|
44
|
+
"gitHead": "b8aec8a1be3f25c3b428b357fe1e352c7cbff9ae",
|
|
45
|
+
"webiny": {
|
|
46
|
+
"publishFrom": "dist"
|
|
47
|
+
}
|
|
45
48
|
}
|
package/routes.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { Route } from "@webiny/app-admin";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
const Routes = {
|
|
3
|
+
Settings: new Route({
|
|
4
|
+
name: "Mailer/Settings",
|
|
5
|
+
path: "/mailer/settings"
|
|
6
|
+
})
|
|
7
7
|
};
|
|
8
|
+
export { Routes };
|
|
8
9
|
|
|
9
10
|
//# sourceMappingURL=routes.js.map
|
package/routes.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"routes.js","sources":["../src/routes.ts"],"sourcesContent":["import { Route } from \"@webiny/app-admin\";\n\nexport const Routes = {\n Settings: new Route({\n name: \"Mailer/Settings\",\n path: \"/mailer/settings\"\n })\n};\n"],"names":["Routes","Route"],"mappings":";AAEO,MAAMA,SAAS;IAClB,UAAU,IAAIC,MAAM;QAChB,MAAM;QACN,MAAM;IACV;AACJ"}
|
package/types.d.ts
CHANGED
package/types.js
CHANGED
|
@@ -1,182 +1,203 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { CenteredView, useSnackbar } from "@webiny/app-admin";
|
|
1
|
+
import react, { useEffect, useRef, useState } from "react";
|
|
2
|
+
import { CenteredView, SimpleForm, SimpleFormContent, SimpleFormFooter, SimpleFormHeader, useSnackbar } from "@webiny/app-admin";
|
|
3
3
|
import { Mutation, Query } from "@apollo/react-components";
|
|
4
4
|
import { Form } from "@webiny/form";
|
|
5
|
-
import { SimpleForm, SimpleFormContent, SimpleFormFooter, SimpleFormHeader } from "@webiny/app-admin";
|
|
6
5
|
import { validation } from "@webiny/validation";
|
|
7
6
|
import { GET_SETTINGS_QUERY, SAVE_SETTINGS_MUTATION } from "./graphql.js";
|
|
8
|
-
import dotPropImmutable from "dot-prop-immutable";
|
|
9
7
|
import { Alert, Button, Grid, Input, OverlayLoader } from "@webiny/admin-ui";
|
|
10
|
-
const displayErrors = errors
|
|
11
|
-
|
|
12
|
-
return null
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
title: "Error",
|
|
22
|
-
type: "danger"
|
|
23
|
-
}, error.message, "ssss");
|
|
24
|
-
}));
|
|
8
|
+
const displayErrors = (errors)=>{
|
|
9
|
+
if (!errors) return null;
|
|
10
|
+
return /*#__PURE__*/ react.createElement(react.Fragment, null, errors.map((error)=>{
|
|
11
|
+
const field = error.path[0];
|
|
12
|
+
if (!field) return null;
|
|
13
|
+
return /*#__PURE__*/ react.createElement(Alert, {
|
|
14
|
+
key: `${field}`,
|
|
15
|
+
title: "Error",
|
|
16
|
+
type: "danger"
|
|
17
|
+
}, error.message);
|
|
18
|
+
}));
|
|
25
19
|
};
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
return
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
},
|
|
39
|
-
return (
|
|
40
|
-
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
20
|
+
const Settings = ()=>{
|
|
21
|
+
const { showSnackbar } = useSnackbar();
|
|
22
|
+
const password = useRef(null);
|
|
23
|
+
const [errors, setErrors] = useState();
|
|
24
|
+
useEffect(()=>{
|
|
25
|
+
const t = setTimeout(()=>{
|
|
26
|
+
if (!password.current) return;
|
|
27
|
+
password.current.value = "";
|
|
28
|
+
}, 300);
|
|
29
|
+
return ()=>{
|
|
30
|
+
clearTimeout(t);
|
|
31
|
+
};
|
|
32
|
+
}, []);
|
|
33
|
+
return /*#__PURE__*/ react.createElement(Query, {
|
|
34
|
+
query: GET_SETTINGS_QUERY
|
|
35
|
+
}, ({ data: response, loading: queryInProgress })=>/*#__PURE__*/ react.createElement(Mutation, {
|
|
36
|
+
mutation: SAVE_SETTINGS_MUTATION
|
|
37
|
+
}, (update, result)=>{
|
|
38
|
+
const { data: settingsData, error: settingsError } = response?.mailer.settings || {};
|
|
39
|
+
const settingsSource = settingsData?.source;
|
|
40
|
+
const { loading: mutationInProgress } = result;
|
|
41
|
+
const onSubmit = async (data)=>{
|
|
42
|
+
setErrors([]);
|
|
43
|
+
const response = await update({
|
|
44
|
+
variables: {
|
|
45
|
+
data
|
|
46
|
+
},
|
|
47
|
+
refetchQueries: [
|
|
48
|
+
{
|
|
49
|
+
query: GET_SETTINGS_QUERY
|
|
50
|
+
}
|
|
51
|
+
],
|
|
52
|
+
awaitRefetchQueries: true
|
|
53
|
+
});
|
|
54
|
+
const saveError = response.data?.mailer.settings.error;
|
|
55
|
+
if (saveError) {
|
|
56
|
+
const validationErrors = saveError.data?.errors;
|
|
57
|
+
if (validationErrors) setErrors(validationErrors);
|
|
58
|
+
showSnackbar("Settings not updated! Please check your network and console logs for detailed information.");
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
showSnackbar("Settings updated successfully.");
|
|
62
|
+
};
|
|
63
|
+
if ("code" === settingsSource) return /*#__PURE__*/ react.createElement(CenteredView, null, /*#__PURE__*/ react.createElement(SimpleForm, null, /*#__PURE__*/ react.createElement(SimpleFormHeader, {
|
|
64
|
+
title: "Mailer Settings"
|
|
65
|
+
}), /*#__PURE__*/ react.createElement(SimpleFormContent, null, /*#__PURE__*/ react.createElement(Grid, null, /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
66
|
+
span: 12
|
|
67
|
+
}, /*#__PURE__*/ react.createElement(Alert, {
|
|
68
|
+
title: "Managed by code",
|
|
69
|
+
type: "info"
|
|
70
|
+
}, "Mailer settings are managed by code. Edit", " ", /*#__PURE__*/ react.createElement("code", null, "webiny.config.tsx"), " to change them.")), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
71
|
+
span: 12
|
|
72
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
73
|
+
size: "lg",
|
|
74
|
+
type: "text",
|
|
75
|
+
label: "Hostname",
|
|
76
|
+
value: settingsData?.host ?? "",
|
|
77
|
+
disabled: true
|
|
78
|
+
})), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
79
|
+
span: 12
|
|
80
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
81
|
+
size: "lg",
|
|
82
|
+
type: "number",
|
|
83
|
+
label: "Port",
|
|
84
|
+
value: String(settingsData?.port ?? ""),
|
|
85
|
+
disabled: true
|
|
86
|
+
})), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
87
|
+
span: 12
|
|
88
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
89
|
+
size: "lg",
|
|
90
|
+
type: "text",
|
|
91
|
+
label: "User",
|
|
92
|
+
value: settingsData?.user ?? "",
|
|
93
|
+
disabled: true
|
|
94
|
+
})), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
95
|
+
span: 12
|
|
96
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
97
|
+
size: "lg",
|
|
98
|
+
type: "text",
|
|
99
|
+
label: "From",
|
|
100
|
+
value: settingsData?.from ?? "",
|
|
101
|
+
disabled: true
|
|
102
|
+
})), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
103
|
+
span: 12
|
|
104
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
105
|
+
size: "lg",
|
|
106
|
+
type: "text",
|
|
107
|
+
label: "Reply-To",
|
|
108
|
+
value: settingsData?.replyTo ?? "",
|
|
109
|
+
disabled: true
|
|
110
|
+
})))), /*#__PURE__*/ react.createElement(SimpleFormFooter, null, "")));
|
|
111
|
+
if (settingsError) return /*#__PURE__*/ react.createElement(SimpleForm, null, /*#__PURE__*/ react.createElement(SimpleFormHeader, {
|
|
112
|
+
title: "Mailer Settings"
|
|
113
|
+
}), /*#__PURE__*/ react.createElement(SimpleFormContent, null, /*#__PURE__*/ react.createElement(Grid, null, /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
114
|
+
span: 12
|
|
115
|
+
}, /*#__PURE__*/ react.createElement(Alert, {
|
|
116
|
+
title: settingsError.message,
|
|
117
|
+
type: "danger"
|
|
118
|
+
})))), /*#__PURE__*/ react.createElement(SimpleFormFooter, null, ""));
|
|
119
|
+
const passwordValidators = [];
|
|
120
|
+
if (!settingsData?.user) passwordValidators.push(validation.create("required,minLength:5"));
|
|
121
|
+
return /*#__PURE__*/ react.createElement(CenteredView, null, /*#__PURE__*/ react.createElement(Form, {
|
|
122
|
+
data: settingsData || {},
|
|
123
|
+
onSubmit: (data)=>{
|
|
124
|
+
onSubmit(data);
|
|
125
|
+
}
|
|
126
|
+
}, ({ Bind, form })=>/*#__PURE__*/ react.createElement(SimpleForm, null, (queryInProgress || mutationInProgress) && /*#__PURE__*/ react.createElement(OverlayLoader, null), /*#__PURE__*/ react.createElement(SimpleFormHeader, {
|
|
127
|
+
title: "Mailer Settings"
|
|
128
|
+
}), /*#__PURE__*/ react.createElement(SimpleFormContent, null, displayErrors(errors), /*#__PURE__*/ react.createElement(Grid, null, /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
129
|
+
span: 12
|
|
130
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
131
|
+
name: "host",
|
|
132
|
+
validators: [
|
|
133
|
+
validation.create("required,minLength:1")
|
|
134
|
+
]
|
|
135
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
136
|
+
size: "lg",
|
|
137
|
+
type: "text",
|
|
138
|
+
label: "Hostname"
|
|
139
|
+
}))), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
140
|
+
span: 12
|
|
141
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
142
|
+
name: "port"
|
|
143
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
144
|
+
size: "lg",
|
|
145
|
+
type: "number",
|
|
146
|
+
label: "Port"
|
|
147
|
+
}))), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
148
|
+
span: 12
|
|
149
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
150
|
+
name: "user",
|
|
151
|
+
validators: [
|
|
152
|
+
validation.create("required,minLength:1")
|
|
153
|
+
]
|
|
154
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
155
|
+
size: "lg",
|
|
156
|
+
type: "text",
|
|
157
|
+
label: "User",
|
|
158
|
+
autoComplete: "new-password"
|
|
159
|
+
}))), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
160
|
+
span: 12
|
|
161
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
162
|
+
name: "password",
|
|
163
|
+
validators: passwordValidators
|
|
164
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
165
|
+
size: "lg",
|
|
166
|
+
label: "Password",
|
|
167
|
+
type: "password",
|
|
168
|
+
autoComplete: "new-password",
|
|
169
|
+
value: "",
|
|
170
|
+
inputRef: password
|
|
171
|
+
}))), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
172
|
+
span: 12
|
|
173
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
174
|
+
name: "from",
|
|
175
|
+
validators: [
|
|
176
|
+
validation.create("required,minLength:1,email")
|
|
177
|
+
]
|
|
178
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
179
|
+
size: "lg",
|
|
180
|
+
type: "text",
|
|
181
|
+
label: "Mail from"
|
|
182
|
+
}))), /*#__PURE__*/ react.createElement(Grid.Column, {
|
|
183
|
+
span: 12
|
|
184
|
+
}, /*#__PURE__*/ react.createElement(Bind, {
|
|
185
|
+
name: "replyTo",
|
|
186
|
+
validators: [
|
|
187
|
+
validation.create("email")
|
|
188
|
+
]
|
|
189
|
+
}, /*#__PURE__*/ react.createElement(Input, {
|
|
190
|
+
size: "lg",
|
|
191
|
+
type: "text",
|
|
192
|
+
label: "Mail reply-to"
|
|
193
|
+
}))))), /*#__PURE__*/ react.createElement(SimpleFormFooter, null, /*#__PURE__*/ react.createElement(Button, {
|
|
194
|
+
text: "Save",
|
|
195
|
+
onClick: (ev)=>{
|
|
196
|
+
form.submit(ev);
|
|
197
|
+
}
|
|
198
|
+
})))));
|
|
199
|
+
}));
|
|
180
200
|
};
|
|
201
|
+
export { Settings };
|
|
181
202
|
|
|
182
203
|
//# sourceMappingURL=Settings.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useEffect","useRef","useState","CenteredView","useSnackbar","Mutation","Query","Form","SimpleForm","SimpleFormContent","SimpleFormFooter","SimpleFormHeader","validation","GET_SETTINGS_QUERY","SAVE_SETTINGS_MUTATION","dotPropImmutable","Alert","Button","Grid","Input","OverlayLoader","displayErrors","errors","createElement","Fragment","map","error","field","path","key","title","type","message","Settings","showSnackbar","password","setErrors","t","setTimeout","current","value","clearTimeout","query","data","response","loading","queryInProgress","mutation","update","result","settingsData","settingsError","mailer","settings","mutationInProgress","onSubmit","variables","cache","structuredClone","readQuery","updateData","updateError","writeQuery","set","Column","span","code","passwordValidators","user","push","create","Bind","form","name","validators","size","label","autoComplete","inputRef","text","onClick","ev","submit"],"sources":["Settings.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport { CenteredView, useSnackbar } from \"@webiny/app-admin\";\nimport { Mutation, Query } from \"@apollo/react-components\";\nimport { Form } from \"@webiny/form\";\nimport {\n SimpleForm,\n SimpleFormContent,\n SimpleFormFooter,\n SimpleFormHeader\n} from \"@webiny/app-admin\";\nimport { validation } from \"@webiny/validation\";\nimport type {\n SaveSettingsMutationResponse,\n SaveSettingsMutationVariables,\n SettingsQueryResponse\n} from \"./graphql.js\";\nimport { GET_SETTINGS_QUERY, SAVE_SETTINGS_MUTATION } from \"./graphql.js\";\nimport type { TransportSettings, ValidationError } from \"~/types.js\";\nimport type { Validator } from \"@webiny/validation/types.js\";\nimport dotPropImmutable from \"dot-prop-immutable\";\nimport { Alert, Button, Grid, Input, OverlayLoader } from \"@webiny/admin-ui\";\n\nconst displayErrors = (errors?: ValidationError[]) => {\n if (!errors) {\n return null;\n }\n return (\n <>\n {errors.map(error => {\n const field = error.path[0];\n if (!field) {\n return null;\n }\n return (\n <Alert key={`${field}`} title={\"Error\"} type=\"danger\">\n {error.message}\n {\"ssss\"}\n </Alert>\n );\n })}\n </>\n );\n};\n\nexport const Settings = () => {\n const { showSnackbar } = useSnackbar();\n\n const password = useRef<HTMLInputElement>(null);\n\n const [errors, setErrors] = useState<ValidationError[] | undefined>();\n\n useEffect(() => {\n const t = setTimeout(() => {\n if (!password.current) {\n return;\n }\n password.current.value = \"\";\n }, 300);\n\n return () => {\n clearTimeout(t);\n };\n }, []);\n\n return (\n <Query<SettingsQueryResponse> query={GET_SETTINGS_QUERY}>\n {({ data: response, loading: queryInProgress }) => (\n <Mutation<SaveSettingsMutationResponse, SaveSettingsMutationVariables>\n mutation={SAVE_SETTINGS_MUTATION}\n >\n {(update, result) => {\n const { data: settingsData, error: settingsError } =\n response?.mailer.settings || {};\n const { loading: mutationInProgress } = result;\n\n const onSubmit = async (data: TransportSettings): Promise<void> => {\n setErrors([]);\n await update({\n variables: {\n data\n },\n update: (cache, result) => {\n const data = structuredClone(\n cache.readQuery<SettingsQueryResponse>({\n query: GET_SETTINGS_QUERY\n })\n );\n\n const { data: updateData, error: updateError } =\n result.data?.mailer.settings || {};\n\n const errors = updateError?.data.errors;\n if (errors) {\n setErrors(errors);\n showSnackbar(\n \"Settings not updated! Please check your network and console logs for detailed information.\"\n );\n return;\n }\n\n cache.writeQuery({\n query: GET_SETTINGS_QUERY,\n data: dotPropImmutable.set(data, \"mailer.settings.data\", {\n ...settingsData,\n ...updateData\n })\n });\n showSnackbar(\"Settings updated successfully.\");\n }\n });\n };\n if (settingsError) {\n return (\n <SimpleForm>\n <SimpleFormHeader title=\"Mailer Settings\" />\n <SimpleFormContent>\n <Grid>\n <Grid.Column span={12}>\n <Alert title={settingsError.message} type=\"danger\">\n {settingsError.code ===\n \"PASSWORD_SECRET_ERROR\" && (\n <p>\n To store the Mailer settings, you must\n have a password secret environment\n variable defined.\n </p>\n )}\n </Alert>\n </Grid.Column>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>{\"\"}</SimpleFormFooter>\n </SimpleForm>\n );\n }\n\n const passwordValidators: Validator[] = [];\n if (!settingsData?.user) {\n passwordValidators.push(validation.create(\"required,minLength:5\"));\n }\n\n return (\n <CenteredView>\n <Form\n data={settingsData || {}}\n onSubmit={data => {\n /**\n * We are positive that data is TransportSettings.\n */\n onSubmit(data as unknown as TransportSettings);\n }}\n >\n {({ Bind, form }) => (\n <SimpleForm>\n {(queryInProgress || mutationInProgress) && (\n <OverlayLoader />\n )}\n <SimpleFormHeader title=\"Mailer Settings\" />\n <SimpleFormContent>\n {displayErrors(errors)}\n <Grid>\n <Grid.Column span={12}>\n <Bind\n name={\"host\"}\n validators={[\n validation.create(\n \"required,minLength:1\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Hostname\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind name={\"port\"}>\n <Input\n size={\"lg\"}\n type=\"number\"\n label=\"Port\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"user\"}\n validators={[\n validation.create(\n \"required,minLength:1\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"User\"\n autoComplete=\"new-password\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"password\"}\n validators={passwordValidators}\n >\n <Input\n size={\"lg\"}\n label=\"Password\"\n type=\"password\"\n autoComplete=\"new-password\"\n value={\"\"}\n inputRef={password}\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"from\"}\n validators={[\n validation.create(\n \"required,minLength:1,email\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Mail from\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"replyTo\"}\n validators={[\n validation.create(\"email\")\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Mail reply-to\"\n />\n </Bind>\n </Grid.Column>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>\n <Button\n text={\"Save\"}\n onClick={ev => {\n form.submit(ev);\n }}\n />\n </SimpleFormFooter>\n </SimpleForm>\n )}\n </Form>\n </CenteredView>\n );\n }}\n </Mutation>\n )}\n </Query>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"views/settings/Settings.js","sources":["../../../src/views/settings/Settings.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport { CenteredView, useSnackbar } from \"@webiny/app-admin\";\nimport { Mutation, Query } from \"@apollo/react-components\";\nimport { Form } from \"@webiny/form\";\nimport {\n SimpleForm,\n SimpleFormContent,\n SimpleFormFooter,\n SimpleFormHeader\n} from \"@webiny/app-admin\";\nimport { validation } from \"@webiny/validation\";\nimport type {\n SaveSettingsMutationResponse,\n SaveSettingsMutationVariables,\n SettingsQueryResponse\n} from \"./graphql.js\";\nimport { GET_SETTINGS_QUERY, SAVE_SETTINGS_MUTATION } from \"./graphql.js\";\nimport type { TransportSettings, ValidationError } from \"~/types.js\";\nimport type { Validator } from \"@webiny/validation/types.js\";\nimport { Alert, Button, Grid, Input, OverlayLoader } from \"@webiny/admin-ui\";\n\nconst displayErrors = (errors?: ValidationError[]) => {\n if (!errors) {\n return null;\n }\n return (\n <>\n {errors.map(error => {\n const field = error.path[0];\n if (!field) {\n return null;\n }\n return (\n <Alert key={`${field}`} title={\"Error\"} type=\"danger\">\n {error.message}\n </Alert>\n );\n })}\n </>\n );\n};\n\nexport const Settings = () => {\n const { showSnackbar } = useSnackbar();\n\n const password = useRef<HTMLInputElement>(null);\n\n const [errors, setErrors] = useState<ValidationError[] | undefined>();\n\n useEffect(() => {\n const t = setTimeout(() => {\n if (!password.current) {\n return;\n }\n password.current.value = \"\";\n }, 300);\n\n return () => {\n clearTimeout(t);\n };\n }, []);\n\n return (\n <Query<SettingsQueryResponse> query={GET_SETTINGS_QUERY}>\n {({ data: response, loading: queryInProgress }) => (\n <Mutation<SaveSettingsMutationResponse, SaveSettingsMutationVariables>\n mutation={SAVE_SETTINGS_MUTATION}\n >\n {(update, result) => {\n const { data: settingsData, error: settingsError } =\n response?.mailer.settings || {};\n const settingsSource = settingsData?.source;\n const { loading: mutationInProgress } = result;\n\n const onSubmit = async (data: TransportSettings): Promise<void> => {\n setErrors([]);\n const response = await update({\n variables: { data },\n refetchQueries: [{ query: GET_SETTINGS_QUERY }],\n awaitRefetchQueries: true\n });\n\n const saveError = response.data?.mailer.settings.error;\n if (saveError) {\n const validationErrors = saveError.data?.errors;\n if (validationErrors) {\n setErrors(validationErrors);\n }\n showSnackbar(\n \"Settings not updated! Please check your network and console logs for detailed information.\"\n );\n return;\n }\n showSnackbar(\"Settings updated successfully.\");\n };\n if (settingsSource === \"code\") {\n return (\n <CenteredView>\n <SimpleForm>\n <SimpleFormHeader title=\"Mailer Settings\" />\n <SimpleFormContent>\n <Grid>\n <Grid.Column span={12}>\n <Alert title=\"Managed by code\" type=\"info\">\n Mailer settings are managed by code. Edit{\" \"}\n <code>webiny.config.tsx</code> to change\n them.\n </Alert>\n </Grid.Column>\n <Grid.Column span={12}>\n <Input\n size=\"lg\"\n type=\"text\"\n label=\"Hostname\"\n value={settingsData?.host ?? \"\"}\n disabled\n />\n </Grid.Column>\n <Grid.Column span={12}>\n <Input\n size=\"lg\"\n type=\"number\"\n label=\"Port\"\n value={String(settingsData?.port ?? \"\")}\n disabled\n />\n </Grid.Column>\n <Grid.Column span={12}>\n <Input\n size=\"lg\"\n type=\"text\"\n label=\"User\"\n value={settingsData?.user ?? \"\"}\n disabled\n />\n </Grid.Column>\n <Grid.Column span={12}>\n <Input\n size=\"lg\"\n type=\"text\"\n label=\"From\"\n value={settingsData?.from ?? \"\"}\n disabled\n />\n </Grid.Column>\n <Grid.Column span={12}>\n <Input\n size=\"lg\"\n type=\"text\"\n label=\"Reply-To\"\n value={settingsData?.replyTo ?? \"\"}\n disabled\n />\n </Grid.Column>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>{\"\"}</SimpleFormFooter>\n </SimpleForm>\n </CenteredView>\n );\n }\n if (settingsError) {\n return (\n <SimpleForm>\n <SimpleFormHeader title=\"Mailer Settings\" />\n <SimpleFormContent>\n <Grid>\n <Grid.Column span={12}>\n <Alert\n title={settingsError.message}\n type=\"danger\"\n />\n </Grid.Column>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>{\"\"}</SimpleFormFooter>\n </SimpleForm>\n );\n }\n\n const passwordValidators: Validator[] = [];\n if (!settingsData?.user) {\n passwordValidators.push(validation.create(\"required,minLength:5\"));\n }\n\n return (\n <CenteredView>\n <Form\n data={settingsData || {}}\n onSubmit={data => {\n /**\n * We are positive that data is TransportSettings.\n */\n onSubmit(data as unknown as TransportSettings);\n }}\n >\n {({ Bind, form }) => (\n <SimpleForm>\n {(queryInProgress || mutationInProgress) && (\n <OverlayLoader />\n )}\n <SimpleFormHeader title=\"Mailer Settings\" />\n <SimpleFormContent>\n {displayErrors(errors)}\n <Grid>\n <Grid.Column span={12}>\n <Bind\n name={\"host\"}\n validators={[\n validation.create(\n \"required,minLength:1\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Hostname\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind name={\"port\"}>\n <Input\n size={\"lg\"}\n type=\"number\"\n label=\"Port\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"user\"}\n validators={[\n validation.create(\n \"required,minLength:1\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"User\"\n autoComplete=\"new-password\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"password\"}\n validators={passwordValidators}\n >\n <Input\n size={\"lg\"}\n label=\"Password\"\n type=\"password\"\n autoComplete=\"new-password\"\n value={\"\"}\n inputRef={password}\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"from\"}\n validators={[\n validation.create(\n \"required,minLength:1,email\"\n )\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Mail from\"\n />\n </Bind>\n </Grid.Column>\n <Grid.Column span={12}>\n <Bind\n name={\"replyTo\"}\n validators={[\n validation.create(\"email\")\n ]}\n >\n <Input\n size={\"lg\"}\n type=\"text\"\n label=\"Mail reply-to\"\n />\n </Bind>\n </Grid.Column>\n </Grid>\n </SimpleFormContent>\n <SimpleFormFooter>\n <Button\n text={\"Save\"}\n onClick={ev => {\n form.submit(ev);\n }}\n />\n </SimpleFormFooter>\n </SimpleForm>\n )}\n </Form>\n </CenteredView>\n );\n }}\n </Mutation>\n )}\n </Query>\n );\n};\n"],"names":["displayErrors","errors","error","field","Alert","Settings","showSnackbar","useSnackbar","password","useRef","setErrors","useState","useEffect","t","setTimeout","clearTimeout","Query","GET_SETTINGS_QUERY","response","queryInProgress","Mutation","SAVE_SETTINGS_MUTATION","update","result","settingsData","settingsError","settingsSource","mutationInProgress","onSubmit","data","saveError","validationErrors","CenteredView","SimpleForm","SimpleFormHeader","SimpleFormContent","Grid","Input","String","SimpleFormFooter","passwordValidators","validation","Form","Bind","form","OverlayLoader","Button","ev"],"mappings":"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"}
|
|
@@ -1,22 +1,25 @@
|
|
|
1
1
|
import type { ApiError, TransportSettings, ValidationErrors } from "../../types.js";
|
|
2
|
+
export type MailerSettingsSource = "code" | "storage" | null;
|
|
3
|
+
/** Settings as they appear in GraphQL responses — never includes the password. */
|
|
4
|
+
export type PublicTransportSettings = Omit<TransportSettings, "password"> & {
|
|
5
|
+
source?: MailerSettingsSource;
|
|
6
|
+
};
|
|
2
7
|
export interface SettingsQueryResponse {
|
|
3
8
|
mailer: {
|
|
4
9
|
settings: {
|
|
5
|
-
data:
|
|
10
|
+
data: PublicTransportSettings | null;
|
|
6
11
|
error: ApiError | null;
|
|
7
12
|
};
|
|
8
13
|
};
|
|
9
14
|
}
|
|
10
15
|
export declare const GET_SETTINGS_QUERY: import("graphql").DocumentNode;
|
|
11
16
|
export interface SaveSettingsMutationVariables {
|
|
12
|
-
data: TransportSettings
|
|
13
|
-
password?: string;
|
|
14
|
-
};
|
|
17
|
+
data: TransportSettings;
|
|
15
18
|
}
|
|
16
19
|
export interface SaveSettingsMutationResponse {
|
|
17
20
|
mailer: {
|
|
18
21
|
settings: {
|
|
19
|
-
data:
|
|
22
|
+
data: PublicTransportSettings | null;
|
|
20
23
|
error: ApiError<ValidationErrors> | null;
|
|
21
24
|
};
|
|
22
25
|
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import graphql_tag from "graphql-tag";
|
|
2
2
|
const SETTINGS_FIELDS = `
|
|
3
3
|
{
|
|
4
4
|
host
|
|
@@ -6,6 +6,7 @@ const SETTINGS_FIELDS = `
|
|
|
6
6
|
user
|
|
7
7
|
from
|
|
8
8
|
replyTo
|
|
9
|
+
source
|
|
9
10
|
}
|
|
10
11
|
`;
|
|
11
12
|
const ERROR_FIELDS = `
|
|
@@ -15,7 +16,7 @@ const ERROR_FIELDS = `
|
|
|
15
16
|
data
|
|
16
17
|
}
|
|
17
18
|
`;
|
|
18
|
-
|
|
19
|
+
const GET_SETTINGS_QUERY = graphql_tag`
|
|
19
20
|
query GetMailerSettings {
|
|
20
21
|
mailer {
|
|
21
22
|
settings: getSettings {
|
|
@@ -25,7 +26,7 @@ export const GET_SETTINGS_QUERY = gql`
|
|
|
25
26
|
}
|
|
26
27
|
}
|
|
27
28
|
`;
|
|
28
|
-
|
|
29
|
+
const SAVE_SETTINGS_MUTATION = graphql_tag`
|
|
29
30
|
mutation SaveTransportSettings($data: MailerTransportSettingsInput!) {
|
|
30
31
|
mailer {
|
|
31
32
|
settings: saveSettings(data: $data) {
|
|
@@ -35,5 +36,6 @@ export const SAVE_SETTINGS_MUTATION = gql`
|
|
|
35
36
|
}
|
|
36
37
|
}
|
|
37
38
|
`;
|
|
39
|
+
export { GET_SETTINGS_QUERY, SAVE_SETTINGS_MUTATION };
|
|
38
40
|
|
|
39
41
|
//# sourceMappingURL=graphql.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"views/settings/graphql.js","sources":["../../../src/views/settings/graphql.ts"],"sourcesContent":["import gql from \"graphql-tag\";\nimport type { ApiError, TransportSettings, ValidationErrors } from \"~/types.js\";\n\nconst SETTINGS_FIELDS = `\n {\n host\n port\n user\n from\n replyTo\n source\n }\n`;\n\nconst ERROR_FIELDS = `\n {\n message\n code\n data\n }\n`;\n\nexport type MailerSettingsSource = \"code\" | \"storage\" | null;\n\n/** Settings as they appear in GraphQL responses — never includes the password. */\nexport type PublicTransportSettings = Omit<TransportSettings, \"password\"> & {\n source?: MailerSettingsSource;\n};\n\nexport interface SettingsQueryResponse {\n mailer: {\n settings: {\n data: PublicTransportSettings | null;\n error: ApiError | null;\n };\n };\n}\nexport const GET_SETTINGS_QUERY = gql`\n query GetMailerSettings {\n mailer {\n settings: getSettings {\n data ${SETTINGS_FIELDS}\n error ${ERROR_FIELDS}\n }\n }\n }\n`;\n\nexport interface SaveSettingsMutationVariables {\n data: TransportSettings;\n}\n\nexport interface SaveSettingsMutationResponse {\n mailer: {\n settings: {\n data: PublicTransportSettings | null;\n error: ApiError<ValidationErrors> | null;\n };\n };\n}\nexport const SAVE_SETTINGS_MUTATION = gql`\n mutation SaveTransportSettings($data: MailerTransportSettingsInput!) {\n mailer {\n settings: saveSettings(data: $data) {\n data ${SETTINGS_FIELDS}\n error ${ERROR_FIELDS}\n }\n }\n }\n`;\n"],"names":["SETTINGS_FIELDS","ERROR_FIELDS","GET_SETTINGS_QUERY","gql","SAVE_SETTINGS_MUTATION"],"mappings":";AAGA,MAAMA,kBAAkB,CAAC;;;;;;;;;AASzB,CAAC;AAED,MAAMC,eAAe,CAAC;;;;;;AAMtB,CAAC;AAiBM,MAAMC,qBAAqBC,WAAG,CAAC;;;;qBAIjB,EAAEH,gBAAgB;sBACjB,EAAEC,aAAa;;;;AAIrC,CAAC;AAcM,MAAMG,yBAAyBD,WAAG,CAAC;;;;qBAIrB,EAAEH,gBAAgB;sBACjB,EAAEC,aAAa;;;;AAIrC,CAAC"}
|
package/views/settings/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"views/settings/index.js","sources":["../../../src/views/settings/index.ts"],"sourcesContent":["import { Settings } from \"./Settings.js\";\n\nexport default Settings;\n"],"names":["Settings"],"mappings":";AAEA,iBAAeA"}
|
package/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["Module"],"sources":["index.tsx"],"sourcesContent":["export { Module } from \"./Module.js\";\n"],"mappings":"AAAA,SAASA,MAAM","ignoreList":[]}
|
package/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import { Identity } from \"@webiny/app-admin/domain/Identity.js\";\n\n/**\n * A base security permission for APW.\n *\n * @category SecurityPermission\n */\nexport interface MailerSecurityPermission extends Identity.Permission {\n changeSettings?: boolean;\n}\n\n/**\n * GraphQL API call response for the transport settings values\n * @category GraphQL\n */\nexport interface TransportSettings {\n host: string;\n user: string;\n from: string;\n replyTo?: string;\n password?: string;\n}\n/**\n *\n * @category GraphQL\n */\nexport interface ApiError<T = Record<string, any>> {\n message: string;\n code: string;\n data: T;\n}\n\n/**\n * Description of the JOI validation errors received from the API.\n *\n * @category GraphQL\n */\nexport interface ValidationError {\n message: string;\n path: string[];\n}\n\nexport interface ValidationErrors {\n errors: ValidationError[];\n}\n"],"mappings":"","ignoreList":[]}
|