@bigbinary/neeto-message-templates-frontend 1.0.2 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ApiTemplates.js +439 -0
- package/dist/ApiTemplates.js.map +1 -0
- package/dist/MessageTemplates.js +1248 -0
- package/dist/MessageTemplates.js.map +1 -0
- package/dist/NoDataPage-00b22095.js +58 -0
- package/dist/NoDataPage-00b22095.js.map +1 -0
- package/dist/NoDataPage-4ba91a9f.js +51 -0
- package/dist/NoDataPage-4ba91a9f.js.map +1 -0
- package/dist/SendMessagePane.js +356 -0
- package/dist/SendMessagePane.js.map +1 -0
- package/dist/SendToApiPane.js +151 -0
- package/dist/SendToApiPane.js.map +1 -0
- package/dist/cjs/ApiTemplates.js +459 -0
- package/dist/cjs/ApiTemplates.js.map +1 -0
- package/dist/cjs/MessageTemplates.js +1289 -0
- package/dist/cjs/MessageTemplates.js.map +1 -0
- package/dist/cjs/SendMessagePane.js +390 -0
- package/dist/cjs/SendMessagePane.js.map +1 -0
- package/dist/cjs/SendToApiPane.js +181 -0
- package/dist/cjs/SendToApiPane.js.map +1 -0
- package/dist/cjs/index.js +61 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/index.js +49 -4587
- package/dist/index.js.map +1 -1
- package/dist/slicedToArray-b4278ecd.js +57 -0
- package/dist/slicedToArray-b4278ecd.js.map +1 -0
- package/dist/slicedToArray-f320d9e7.js +61 -0
- package/dist/slicedToArray-f320d9e7.js.map +1 -0
- package/dist/toConsumableArray-1cc38429.js +20 -0
- package/dist/toConsumableArray-1cc38429.js.map +1 -0
- package/dist/toConsumableArray-9abb3858.js +22 -0
- package/dist/toConsumableArray-9abb3858.js.map +1 -0
- package/dist/useTemplatesApi-45d43d41.js +2240 -0
- package/dist/useTemplatesApi-45d43d41.js.map +1 -0
- package/dist/useTemplatesApi-943ef380.js +2256 -0
- package/dist/useTemplatesApi-943ef380.js.map +1 -0
- package/dist/utils-90248b52.js +188 -0
- package/dist/utils-90248b52.js.map +1 -0
- package/dist/utils-b93467c8.js +151 -0
- package/dist/utils-b93467c8.js.map +1 -0
- package/package.json +24 -12
- package/dist/index.cjs.js +0 -4642
- package/dist/index.cjs.js.map +0 -1
|
@@ -0,0 +1,1248 @@
|
|
|
1
|
+
import { u as useUpdateTemplate, _ as _defineProperty, g as getDefaultExportFromCjs, D as DEFAULT_EDITOR_ROW_COUNT, a as DEFAULT_PAGE_PROPERTIES, M as MESSAGE_TEMPLATES, b as useFetchTemplates, c as useCreateTemplate, d as useDeleteTemplate, e as MESSAGE_TYPES } from './useTemplatesApi-45d43d41.js';
|
|
2
|
+
import { _ as _slicedToArray } from './slicedToArray-b4278ecd.js';
|
|
3
|
+
import { useState, useRef, useEffect } from 'react';
|
|
4
|
+
import { hyphenate, noop, isNotEmpty } from '@bigbinary/neeto-cist';
|
|
5
|
+
import { buildFiltersFromURL, Bar } from '@bigbinary/neeto-filters-frontend';
|
|
6
|
+
import Container from '@bigbinary/neeto-molecules/Container';
|
|
7
|
+
import NeetoHeader from '@bigbinary/neeto-molecules/Header';
|
|
8
|
+
import HelpPopover from '@bigbinary/neeto-molecules/HelpPopover';
|
|
9
|
+
import SubHeader from '@bigbinary/neeto-molecules/SubHeader';
|
|
10
|
+
import Button from '@bigbinary/neetoui/Button';
|
|
11
|
+
import Typography from '@bigbinary/neetoui/Typography';
|
|
12
|
+
import { equals, prop, includes, pick, omit, isEmpty, assoc } from 'ramda';
|
|
13
|
+
import { useTranslation, Trans } from 'react-i18next';
|
|
14
|
+
import { t } from 'i18next';
|
|
15
|
+
import MoreDropdown from '@bigbinary/neeto-molecules/MoreDropdown';
|
|
16
|
+
import { withImmutableActions, useQueryParams } from '@bigbinary/neeto-commons-frontend/react-utils';
|
|
17
|
+
import { create } from 'zustand';
|
|
18
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
19
|
+
import Pane from '@bigbinary/neetoui/Pane';
|
|
20
|
+
import FormikEditor from '@bigbinary/neeto-editor/FormikEditor';
|
|
21
|
+
import NeetoUIForm from '@bigbinary/neetoui/formik/Form';
|
|
22
|
+
import Input from '@bigbinary/neetoui/formik/Input';
|
|
23
|
+
import ActionBlock from '@bigbinary/neetoui/formik/ActionBlock';
|
|
24
|
+
import { useFormikContext } from 'formik';
|
|
25
|
+
import Textarea from '@bigbinary/neetoui/formik/Textarea';
|
|
26
|
+
import 'stylesheets/application.scss';
|
|
27
|
+
import { isPhoneNumberValid } from '@bigbinary/neeto-molecules/PhoneNumber';
|
|
28
|
+
import * as yup from 'yup';
|
|
29
|
+
import { _ as _toConsumableArray } from './toConsumableArray-1cc38429.js';
|
|
30
|
+
import TableWrapper from '@bigbinary/neeto-molecules/TableWrapper';
|
|
31
|
+
import Alert from '@bigbinary/neetoui/Alert';
|
|
32
|
+
import Table from '@bigbinary/neetoui/Table';
|
|
33
|
+
import NoData from '@bigbinary/neetoui/NoData';
|
|
34
|
+
import '@bigbinary/neeto-commons-frontend/constants';
|
|
35
|
+
import '@tanstack/react-query';
|
|
36
|
+
import 'axios';
|
|
37
|
+
import 'util';
|
|
38
|
+
|
|
39
|
+
var MESSAGE_TEMPLATE_INITIAL_STATE = {
|
|
40
|
+
isOpen: false,
|
|
41
|
+
isEdit: false,
|
|
42
|
+
isDelete: false,
|
|
43
|
+
template: {}
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
/** @type {import("neetocommons/react-utils").ZustandStoreHook} */
|
|
47
|
+
var useTemplateStore = create(withImmutableActions(function (set) {
|
|
48
|
+
return {
|
|
49
|
+
templateType: "",
|
|
50
|
+
setTemplateState: set
|
|
51
|
+
};
|
|
52
|
+
}));
|
|
53
|
+
|
|
54
|
+
var MENU_ITEMS = {
|
|
55
|
+
EDIT: "edit",
|
|
56
|
+
DELETE: "delete",
|
|
57
|
+
STATUS: "status"
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
var getMenuItems = function getMenuItems(_ref) {
|
|
61
|
+
var handleDeleteTemplate = _ref.handleDeleteTemplate,
|
|
62
|
+
handleEditTemplate = _ref.handleEditTemplate,
|
|
63
|
+
handleMarkActiveInactive = _ref.handleMarkActiveInactive,
|
|
64
|
+
status = _ref.status;
|
|
65
|
+
return [{
|
|
66
|
+
key: MENU_ITEMS.EDIT,
|
|
67
|
+
label: t("neetoMessageTemplate.template.edit"),
|
|
68
|
+
onClick: handleEditTemplate,
|
|
69
|
+
"data-cy": "message-template-edit-button"
|
|
70
|
+
}, {
|
|
71
|
+
key: MENU_ITEMS.STATUS,
|
|
72
|
+
label: equals(status, "active") ? t("neetoMessageTemplate.template.markAsInactive") : t("neetoMessageTemplate.template.markAsActive"),
|
|
73
|
+
onClick: function onClick() {
|
|
74
|
+
return handleMarkActiveInactive(status);
|
|
75
|
+
},
|
|
76
|
+
"data-cy": "message-template-status-button"
|
|
77
|
+
}, {
|
|
78
|
+
key: MENU_ITEMS.DELETE,
|
|
79
|
+
label: t("neetoMessageTemplate.template.delete"),
|
|
80
|
+
onClick: handleDeleteTemplate,
|
|
81
|
+
"data-cy": "message-template-delete-button"
|
|
82
|
+
}];
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
function ownKeys$6(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
86
|
+
function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$6(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$6(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
87
|
+
var RowActions = function RowActions(_ref) {
|
|
88
|
+
var template = _ref.template,
|
|
89
|
+
setManageTemplatePane = _ref.setManageTemplatePane,
|
|
90
|
+
ownerId = _ref.ownerId,
|
|
91
|
+
onMutationSuccess = _ref.onMutationSuccess;
|
|
92
|
+
var _useUpdateTemplate = useUpdateTemplate(ownerId),
|
|
93
|
+
update = _useUpdateTemplate.mutate;
|
|
94
|
+
var status = template.status,
|
|
95
|
+
id = template.id;
|
|
96
|
+
var templateType = useTemplateStore(prop("templateType"));
|
|
97
|
+
var handleEditTemplate = function handleEditTemplate() {
|
|
98
|
+
return setManageTemplatePane(_objectSpread$6(_objectSpread$6({}, MESSAGE_TEMPLATE_INITIAL_STATE), {}, {
|
|
99
|
+
isOpen: true,
|
|
100
|
+
isEdit: true,
|
|
101
|
+
template: template
|
|
102
|
+
}));
|
|
103
|
+
};
|
|
104
|
+
var handleDeleteTemplate = function handleDeleteTemplate() {
|
|
105
|
+
return setManageTemplatePane(_objectSpread$6(_objectSpread$6({}, MESSAGE_TEMPLATE_INITIAL_STATE), {}, {
|
|
106
|
+
isDelete: true,
|
|
107
|
+
template: template
|
|
108
|
+
}));
|
|
109
|
+
};
|
|
110
|
+
var handleMarkActiveInactive = function handleMarkActiveInactive(activeState) {
|
|
111
|
+
var status = activeState === "active" ? "inactive" : "active";
|
|
112
|
+
update({
|
|
113
|
+
payload: {
|
|
114
|
+
status: status,
|
|
115
|
+
templateType: templateType
|
|
116
|
+
},
|
|
117
|
+
id: id
|
|
118
|
+
}, {
|
|
119
|
+
onSuccess: onMutationSuccess
|
|
120
|
+
});
|
|
121
|
+
};
|
|
122
|
+
return /*#__PURE__*/jsx(MoreDropdown, {
|
|
123
|
+
dropdownButtonProps: {
|
|
124
|
+
"data-cy": "message-template-dropdown"
|
|
125
|
+
},
|
|
126
|
+
dropdownProps: {
|
|
127
|
+
strategy: "fixed"
|
|
128
|
+
},
|
|
129
|
+
menuItems: getMenuItems({
|
|
130
|
+
handleDeleteTemplate: handleDeleteTemplate,
|
|
131
|
+
handleEditTemplate: handleEditTemplate,
|
|
132
|
+
handleMarkActiveInactive: handleMarkActiveInactive,
|
|
133
|
+
status: status
|
|
134
|
+
})
|
|
135
|
+
});
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
function ownKeys$5(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
139
|
+
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$5(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$5(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
140
|
+
var handleEditTemplate = function handleEditTemplate(setManageTemplatePane, template) {
|
|
141
|
+
return setManageTemplatePane(_objectSpread$5(_objectSpread$5({}, MESSAGE_TEMPLATE_INITIAL_STATE), {}, {
|
|
142
|
+
isOpen: true,
|
|
143
|
+
isEdit: true,
|
|
144
|
+
template: template
|
|
145
|
+
}));
|
|
146
|
+
};
|
|
147
|
+
var renderSearchProps = function renderSearchProps(label, value) {
|
|
148
|
+
return {
|
|
149
|
+
className: "w-52",
|
|
150
|
+
placeholder: t("neetoMessageTemplate.template.search", {
|
|
151
|
+
what: label
|
|
152
|
+
}),
|
|
153
|
+
"data-cy": "".concat(hyphenate(value), "-search-input")
|
|
154
|
+
};
|
|
155
|
+
};
|
|
156
|
+
var buildTableColumnData = function buildTableColumnData(setManageTemplatePane, ownerId, onMutationSuccess) {
|
|
157
|
+
return [{
|
|
158
|
+
dataIndex: "name",
|
|
159
|
+
key: "name",
|
|
160
|
+
node: "name",
|
|
161
|
+
title: t("neetoMessageTemplate.template.name"),
|
|
162
|
+
label: t("neetoMessageTemplate.template.name"),
|
|
163
|
+
type: "text",
|
|
164
|
+
render: function render(name, template) {
|
|
165
|
+
return /*#__PURE__*/jsxs("div", {
|
|
166
|
+
className: "flex items-center justify-between gap-x-3",
|
|
167
|
+
children: [/*#__PURE__*/jsx(Button, {
|
|
168
|
+
label: name,
|
|
169
|
+
style: "link",
|
|
170
|
+
onClick: function onClick() {
|
|
171
|
+
return handleEditTemplate(setManageTemplatePane, template);
|
|
172
|
+
}
|
|
173
|
+
}), /*#__PURE__*/jsx(RowActions, {
|
|
174
|
+
onMutationSuccess: onMutationSuccess,
|
|
175
|
+
ownerId: ownerId,
|
|
176
|
+
setManageTemplatePane: setManageTemplatePane,
|
|
177
|
+
template: template
|
|
178
|
+
})]
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
}, {
|
|
182
|
+
dataIndex: "status",
|
|
183
|
+
key: "status",
|
|
184
|
+
node: "status",
|
|
185
|
+
title: t("neetoMessageTemplate.template.active"),
|
|
186
|
+
label: t("neetoMessageTemplate.template.active"),
|
|
187
|
+
type: "single_option",
|
|
188
|
+
values: [{
|
|
189
|
+
label: "Yes",
|
|
190
|
+
value: "active"
|
|
191
|
+
}, {
|
|
192
|
+
label: "No",
|
|
193
|
+
value: "inactive"
|
|
194
|
+
}],
|
|
195
|
+
render: function render(status) {
|
|
196
|
+
return status === "active" ? "Yes" : "No";
|
|
197
|
+
},
|
|
198
|
+
width: "20%"
|
|
199
|
+
}];
|
|
200
|
+
};
|
|
201
|
+
|
|
202
|
+
function _objectWithoutPropertiesLoose(source, excluded) {
|
|
203
|
+
if (source == null) return {};
|
|
204
|
+
var target = {};
|
|
205
|
+
var sourceKeys = Object.keys(source);
|
|
206
|
+
var key, i;
|
|
207
|
+
for (i = 0; i < sourceKeys.length; i++) {
|
|
208
|
+
key = sourceKeys[i];
|
|
209
|
+
if (excluded.indexOf(key) >= 0) continue;
|
|
210
|
+
target[key] = source[key];
|
|
211
|
+
}
|
|
212
|
+
return target;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
function _objectWithoutProperties(source, excluded) {
|
|
216
|
+
if (source == null) return {};
|
|
217
|
+
var target = _objectWithoutPropertiesLoose(source, excluded);
|
|
218
|
+
var key, i;
|
|
219
|
+
if (Object.getOwnPropertySymbols) {
|
|
220
|
+
var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
|
|
221
|
+
for (i = 0; i < sourceSymbolKeys.length; i++) {
|
|
222
|
+
key = sourceSymbolKeys[i];
|
|
223
|
+
if (excluded.indexOf(key) >= 0) continue;
|
|
224
|
+
if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
|
|
225
|
+
target[key] = source[key];
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
return target;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
var _excluded = ["label", "name"];
|
|
232
|
+
function ownKeys$4(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
233
|
+
function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$4(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$4(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
234
|
+
var FormikAdaptiveInput = function FormikAdaptiveInput(_ref) {
|
|
235
|
+
var label = _ref.label,
|
|
236
|
+
name = _ref.name,
|
|
237
|
+
otherProps = _objectWithoutProperties(_ref, _excluded);
|
|
238
|
+
var _useFormikContext = useFormikContext(),
|
|
239
|
+
submitForm = _useFormikContext.submitForm;
|
|
240
|
+
var handleKeyDown = function handleKeyDown(event) {
|
|
241
|
+
if (event.key !== "Enter" || event.shiftKey) return;
|
|
242
|
+
event.preventDefault();
|
|
243
|
+
submitForm();
|
|
244
|
+
};
|
|
245
|
+
return /*#__PURE__*/jsx(Textarea, _objectSpread$4({
|
|
246
|
+
label: label,
|
|
247
|
+
name: name,
|
|
248
|
+
className: "neeto-message-templates-nano-adaptive-input",
|
|
249
|
+
resize: "none",
|
|
250
|
+
size: "small",
|
|
251
|
+
onKeyDown: handleKeyDown
|
|
252
|
+
}, otherProps));
|
|
253
|
+
};
|
|
254
|
+
|
|
255
|
+
// eslint-disable-next-line @bigbinary/neeto/file-name-and-export-name-standards
|
|
256
|
+
var formatEditorContent = function formatEditorContent(value) {
|
|
257
|
+
return value === null || value === void 0 ? void 0 : value.replaceAll(/<\/?(?!img)\w*\b[^>]*>/gi, "").trim();
|
|
258
|
+
};
|
|
259
|
+
var EMAIL_TEMPLATE_INITIAL_VALUES = {
|
|
260
|
+
name: "",
|
|
261
|
+
subject: "",
|
|
262
|
+
body: "",
|
|
263
|
+
testEmailAddress: ""
|
|
264
|
+
};
|
|
265
|
+
var SMS_TEMPLATE_INITIAL_VALUES = {
|
|
266
|
+
name: "",
|
|
267
|
+
body: "",
|
|
268
|
+
testPhoneNumber: ""
|
|
269
|
+
};
|
|
270
|
+
var EMAIL_TEMPLATE_FORM_SCHEMA = yup.object({
|
|
271
|
+
name: yup.string().trim().required(t("neetoMessageTemplate.template.validation.namePresence")),
|
|
272
|
+
subject: yup.string().trim().required(t("neetoMessageTemplate.template.validation.subjectPresence")),
|
|
273
|
+
body: yup.string().test("name", t("neetoMessageTemplate.template.validation.bodyPresence"), function (value) {
|
|
274
|
+
return !!formatEditorContent(value);
|
|
275
|
+
})
|
|
276
|
+
});
|
|
277
|
+
var SMS_TEMPLATE_FORM_VALIDATION_SCHEMA = yup.object({
|
|
278
|
+
name: yup.string().trim().required(t("neetoMessageTemplate.template.validation.namePresence")),
|
|
279
|
+
body: yup.string().test("body", t("neetoMessageTemplate.template.validation.bodyPresence"), function (value) {
|
|
280
|
+
return !!formatEditorContent(value);
|
|
281
|
+
})
|
|
282
|
+
});
|
|
283
|
+
var SEND_TEST_EMAIL_SCHEMA = yup.string().trim().required(t("neetoMessageTemplate.template.validation.emailAddressPresence")).email(t("neetoMessageTemplate.template.validation.emailAddressFormatValidation"));
|
|
284
|
+
var PHONE_NUMBER_VALIDATION_SCHEMA = yup.string().test("testPhoneNumber", t("neetoMessageTemplate.template.validation.validPhoneNumber"), function (value) {
|
|
285
|
+
return isPhoneNumberValid(value);
|
|
286
|
+
});
|
|
287
|
+
|
|
288
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
289
|
+
try {
|
|
290
|
+
var info = gen[key](arg);
|
|
291
|
+
var value = info.value;
|
|
292
|
+
} catch (error) {
|
|
293
|
+
reject(error);
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
if (info.done) {
|
|
297
|
+
resolve(value);
|
|
298
|
+
} else {
|
|
299
|
+
Promise.resolve(value).then(_next, _throw);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
function _asyncToGenerator(fn) {
|
|
303
|
+
return function () {
|
|
304
|
+
var self = this,
|
|
305
|
+
args = arguments;
|
|
306
|
+
return new Promise(function (resolve, reject) {
|
|
307
|
+
var gen = fn.apply(self, args);
|
|
308
|
+
function _next(value) {
|
|
309
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
310
|
+
}
|
|
311
|
+
function _throw(err) {
|
|
312
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
313
|
+
}
|
|
314
|
+
_next(undefined);
|
|
315
|
+
});
|
|
316
|
+
};
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
var regeneratorRuntime$1 = {exports: {}};
|
|
320
|
+
|
|
321
|
+
var _typeof = {exports: {}};
|
|
322
|
+
|
|
323
|
+
_typeof.exports;
|
|
324
|
+
|
|
325
|
+
(function (module) {
|
|
326
|
+
function _typeof(o) {
|
|
327
|
+
"@babel/helpers - typeof";
|
|
328
|
+
|
|
329
|
+
return (module.exports = _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) {
|
|
330
|
+
return typeof o;
|
|
331
|
+
} : function (o) {
|
|
332
|
+
return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o;
|
|
333
|
+
}, module.exports.__esModule = true, module.exports["default"] = module.exports), _typeof(o);
|
|
334
|
+
}
|
|
335
|
+
module.exports = _typeof, module.exports.__esModule = true, module.exports["default"] = module.exports;
|
|
336
|
+
} (_typeof));
|
|
337
|
+
|
|
338
|
+
var _typeofExports = _typeof.exports;
|
|
339
|
+
|
|
340
|
+
regeneratorRuntime$1.exports;
|
|
341
|
+
|
|
342
|
+
(function (module) {
|
|
343
|
+
var _typeof = _typeofExports["default"];
|
|
344
|
+
function _regeneratorRuntime() {
|
|
345
|
+
module.exports = _regeneratorRuntime = function _regeneratorRuntime() {
|
|
346
|
+
return e;
|
|
347
|
+
}, module.exports.__esModule = true, module.exports["default"] = module.exports;
|
|
348
|
+
var t,
|
|
349
|
+
e = {},
|
|
350
|
+
r = Object.prototype,
|
|
351
|
+
n = r.hasOwnProperty,
|
|
352
|
+
o = Object.defineProperty || function (t, e, r) {
|
|
353
|
+
t[e] = r.value;
|
|
354
|
+
},
|
|
355
|
+
i = "function" == typeof Symbol ? Symbol : {},
|
|
356
|
+
a = i.iterator || "@@iterator",
|
|
357
|
+
c = i.asyncIterator || "@@asyncIterator",
|
|
358
|
+
u = i.toStringTag || "@@toStringTag";
|
|
359
|
+
function define(t, e, r) {
|
|
360
|
+
return Object.defineProperty(t, e, {
|
|
361
|
+
value: r,
|
|
362
|
+
enumerable: !0,
|
|
363
|
+
configurable: !0,
|
|
364
|
+
writable: !0
|
|
365
|
+
}), t[e];
|
|
366
|
+
}
|
|
367
|
+
try {
|
|
368
|
+
define({}, "");
|
|
369
|
+
} catch (t) {
|
|
370
|
+
define = function define(t, e, r) {
|
|
371
|
+
return t[e] = r;
|
|
372
|
+
};
|
|
373
|
+
}
|
|
374
|
+
function wrap(t, e, r, n) {
|
|
375
|
+
var i = e && e.prototype instanceof Generator ? e : Generator,
|
|
376
|
+
a = Object.create(i.prototype),
|
|
377
|
+
c = new Context(n || []);
|
|
378
|
+
return o(a, "_invoke", {
|
|
379
|
+
value: makeInvokeMethod(t, r, c)
|
|
380
|
+
}), a;
|
|
381
|
+
}
|
|
382
|
+
function tryCatch(t, e, r) {
|
|
383
|
+
try {
|
|
384
|
+
return {
|
|
385
|
+
type: "normal",
|
|
386
|
+
arg: t.call(e, r)
|
|
387
|
+
};
|
|
388
|
+
} catch (t) {
|
|
389
|
+
return {
|
|
390
|
+
type: "throw",
|
|
391
|
+
arg: t
|
|
392
|
+
};
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
e.wrap = wrap;
|
|
396
|
+
var h = "suspendedStart",
|
|
397
|
+
l = "suspendedYield",
|
|
398
|
+
f = "executing",
|
|
399
|
+
s = "completed",
|
|
400
|
+
y = {};
|
|
401
|
+
function Generator() {}
|
|
402
|
+
function GeneratorFunction() {}
|
|
403
|
+
function GeneratorFunctionPrototype() {}
|
|
404
|
+
var p = {};
|
|
405
|
+
define(p, a, function () {
|
|
406
|
+
return this;
|
|
407
|
+
});
|
|
408
|
+
var d = Object.getPrototypeOf,
|
|
409
|
+
v = d && d(d(values([])));
|
|
410
|
+
v && v !== r && n.call(v, a) && (p = v);
|
|
411
|
+
var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
|
|
412
|
+
function defineIteratorMethods(t) {
|
|
413
|
+
["next", "throw", "return"].forEach(function (e) {
|
|
414
|
+
define(t, e, function (t) {
|
|
415
|
+
return this._invoke(e, t);
|
|
416
|
+
});
|
|
417
|
+
});
|
|
418
|
+
}
|
|
419
|
+
function AsyncIterator(t, e) {
|
|
420
|
+
function invoke(r, o, i, a) {
|
|
421
|
+
var c = tryCatch(t[r], t, o);
|
|
422
|
+
if ("throw" !== c.type) {
|
|
423
|
+
var u = c.arg,
|
|
424
|
+
h = u.value;
|
|
425
|
+
return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
|
|
426
|
+
invoke("next", t, i, a);
|
|
427
|
+
}, function (t) {
|
|
428
|
+
invoke("throw", t, i, a);
|
|
429
|
+
}) : e.resolve(h).then(function (t) {
|
|
430
|
+
u.value = t, i(u);
|
|
431
|
+
}, function (t) {
|
|
432
|
+
return invoke("throw", t, i, a);
|
|
433
|
+
});
|
|
434
|
+
}
|
|
435
|
+
a(c.arg);
|
|
436
|
+
}
|
|
437
|
+
var r;
|
|
438
|
+
o(this, "_invoke", {
|
|
439
|
+
value: function value(t, n) {
|
|
440
|
+
function callInvokeWithMethodAndArg() {
|
|
441
|
+
return new e(function (e, r) {
|
|
442
|
+
invoke(t, n, e, r);
|
|
443
|
+
});
|
|
444
|
+
}
|
|
445
|
+
return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();
|
|
446
|
+
}
|
|
447
|
+
});
|
|
448
|
+
}
|
|
449
|
+
function makeInvokeMethod(e, r, n) {
|
|
450
|
+
var o = h;
|
|
451
|
+
return function (i, a) {
|
|
452
|
+
if (o === f) throw new Error("Generator is already running");
|
|
453
|
+
if (o === s) {
|
|
454
|
+
if ("throw" === i) throw a;
|
|
455
|
+
return {
|
|
456
|
+
value: t,
|
|
457
|
+
done: !0
|
|
458
|
+
};
|
|
459
|
+
}
|
|
460
|
+
for (n.method = i, n.arg = a;;) {
|
|
461
|
+
var c = n.delegate;
|
|
462
|
+
if (c) {
|
|
463
|
+
var u = maybeInvokeDelegate(c, n);
|
|
464
|
+
if (u) {
|
|
465
|
+
if (u === y) continue;
|
|
466
|
+
return u;
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
|
|
470
|
+
if (o === h) throw o = s, n.arg;
|
|
471
|
+
n.dispatchException(n.arg);
|
|
472
|
+
} else "return" === n.method && n.abrupt("return", n.arg);
|
|
473
|
+
o = f;
|
|
474
|
+
var p = tryCatch(e, r, n);
|
|
475
|
+
if ("normal" === p.type) {
|
|
476
|
+
if (o = n.done ? s : l, p.arg === y) continue;
|
|
477
|
+
return {
|
|
478
|
+
value: p.arg,
|
|
479
|
+
done: n.done
|
|
480
|
+
};
|
|
481
|
+
}
|
|
482
|
+
"throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
|
|
483
|
+
}
|
|
484
|
+
};
|
|
485
|
+
}
|
|
486
|
+
function maybeInvokeDelegate(e, r) {
|
|
487
|
+
var n = r.method,
|
|
488
|
+
o = e.iterator[n];
|
|
489
|
+
if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
|
|
490
|
+
var i = tryCatch(o, e.iterator, r.arg);
|
|
491
|
+
if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
|
|
492
|
+
var a = i.arg;
|
|
493
|
+
return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
|
|
494
|
+
}
|
|
495
|
+
function pushTryEntry(t) {
|
|
496
|
+
var e = {
|
|
497
|
+
tryLoc: t[0]
|
|
498
|
+
};
|
|
499
|
+
1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
|
|
500
|
+
}
|
|
501
|
+
function resetTryEntry(t) {
|
|
502
|
+
var e = t.completion || {};
|
|
503
|
+
e.type = "normal", delete e.arg, t.completion = e;
|
|
504
|
+
}
|
|
505
|
+
function Context(t) {
|
|
506
|
+
this.tryEntries = [{
|
|
507
|
+
tryLoc: "root"
|
|
508
|
+
}], t.forEach(pushTryEntry, this), this.reset(!0);
|
|
509
|
+
}
|
|
510
|
+
function values(e) {
|
|
511
|
+
if (e || "" === e) {
|
|
512
|
+
var r = e[a];
|
|
513
|
+
if (r) return r.call(e);
|
|
514
|
+
if ("function" == typeof e.next) return e;
|
|
515
|
+
if (!isNaN(e.length)) {
|
|
516
|
+
var o = -1,
|
|
517
|
+
i = function next() {
|
|
518
|
+
for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next;
|
|
519
|
+
return next.value = t, next.done = !0, next;
|
|
520
|
+
};
|
|
521
|
+
return i.next = i;
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
throw new TypeError(_typeof(e) + " is not iterable");
|
|
525
|
+
}
|
|
526
|
+
return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", {
|
|
527
|
+
value: GeneratorFunctionPrototype,
|
|
528
|
+
configurable: !0
|
|
529
|
+
}), o(GeneratorFunctionPrototype, "constructor", {
|
|
530
|
+
value: GeneratorFunction,
|
|
531
|
+
configurable: !0
|
|
532
|
+
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
|
|
533
|
+
var e = "function" == typeof t && t.constructor;
|
|
534
|
+
return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
|
|
535
|
+
}, e.mark = function (t) {
|
|
536
|
+
return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
|
|
537
|
+
}, e.awrap = function (t) {
|
|
538
|
+
return {
|
|
539
|
+
__await: t
|
|
540
|
+
};
|
|
541
|
+
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
|
|
542
|
+
return this;
|
|
543
|
+
}), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
|
|
544
|
+
void 0 === i && (i = Promise);
|
|
545
|
+
var a = new AsyncIterator(wrap(t, r, n, o), i);
|
|
546
|
+
return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
|
|
547
|
+
return t.done ? t.value : a.next();
|
|
548
|
+
});
|
|
549
|
+
}, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
|
|
550
|
+
return this;
|
|
551
|
+
}), define(g, "toString", function () {
|
|
552
|
+
return "[object Generator]";
|
|
553
|
+
}), e.keys = function (t) {
|
|
554
|
+
var e = Object(t),
|
|
555
|
+
r = [];
|
|
556
|
+
for (var n in e) r.push(n);
|
|
557
|
+
return r.reverse(), function next() {
|
|
558
|
+
for (; r.length;) {
|
|
559
|
+
var t = r.pop();
|
|
560
|
+
if (t in e) return next.value = t, next.done = !1, next;
|
|
561
|
+
}
|
|
562
|
+
return next.done = !0, next;
|
|
563
|
+
};
|
|
564
|
+
}, e.values = values, Context.prototype = {
|
|
565
|
+
constructor: Context,
|
|
566
|
+
reset: function reset(e) {
|
|
567
|
+
if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t);
|
|
568
|
+
},
|
|
569
|
+
stop: function stop() {
|
|
570
|
+
this.done = !0;
|
|
571
|
+
var t = this.tryEntries[0].completion;
|
|
572
|
+
if ("throw" === t.type) throw t.arg;
|
|
573
|
+
return this.rval;
|
|
574
|
+
},
|
|
575
|
+
dispatchException: function dispatchException(e) {
|
|
576
|
+
if (this.done) throw e;
|
|
577
|
+
var r = this;
|
|
578
|
+
function handle(n, o) {
|
|
579
|
+
return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
|
|
580
|
+
}
|
|
581
|
+
for (var o = this.tryEntries.length - 1; o >= 0; --o) {
|
|
582
|
+
var i = this.tryEntries[o],
|
|
583
|
+
a = i.completion;
|
|
584
|
+
if ("root" === i.tryLoc) return handle("end");
|
|
585
|
+
if (i.tryLoc <= this.prev) {
|
|
586
|
+
var c = n.call(i, "catchLoc"),
|
|
587
|
+
u = n.call(i, "finallyLoc");
|
|
588
|
+
if (c && u) {
|
|
589
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
590
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
591
|
+
} else if (c) {
|
|
592
|
+
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
593
|
+
} else {
|
|
594
|
+
if (!u) throw new Error("try statement without catch or finally");
|
|
595
|
+
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
596
|
+
}
|
|
597
|
+
}
|
|
598
|
+
}
|
|
599
|
+
},
|
|
600
|
+
abrupt: function abrupt(t, e) {
|
|
601
|
+
for (var r = this.tryEntries.length - 1; r >= 0; --r) {
|
|
602
|
+
var o = this.tryEntries[r];
|
|
603
|
+
if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
|
|
604
|
+
var i = o;
|
|
605
|
+
break;
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
|
|
609
|
+
var a = i ? i.completion : {};
|
|
610
|
+
return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
|
|
611
|
+
},
|
|
612
|
+
complete: function complete(t, e) {
|
|
613
|
+
if ("throw" === t.type) throw t.arg;
|
|
614
|
+
return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
|
|
615
|
+
},
|
|
616
|
+
finish: function finish(t) {
|
|
617
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
618
|
+
var r = this.tryEntries[e];
|
|
619
|
+
if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
|
|
620
|
+
}
|
|
621
|
+
},
|
|
622
|
+
"catch": function _catch(t) {
|
|
623
|
+
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
624
|
+
var r = this.tryEntries[e];
|
|
625
|
+
if (r.tryLoc === t) {
|
|
626
|
+
var n = r.completion;
|
|
627
|
+
if ("throw" === n.type) {
|
|
628
|
+
var o = n.arg;
|
|
629
|
+
resetTryEntry(r);
|
|
630
|
+
}
|
|
631
|
+
return o;
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
throw new Error("illegal catch attempt");
|
|
635
|
+
},
|
|
636
|
+
delegateYield: function delegateYield(e, r, n) {
|
|
637
|
+
return this.delegate = {
|
|
638
|
+
iterator: values(e),
|
|
639
|
+
resultName: r,
|
|
640
|
+
nextLoc: n
|
|
641
|
+
}, "next" === this.method && (this.arg = t), y;
|
|
642
|
+
}
|
|
643
|
+
}, e;
|
|
644
|
+
}
|
|
645
|
+
module.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports["default"] = module.exports;
|
|
646
|
+
} (regeneratorRuntime$1));
|
|
647
|
+
|
|
648
|
+
var regeneratorRuntimeExports = regeneratorRuntime$1.exports;
|
|
649
|
+
|
|
650
|
+
// TODO(Babel 8): Remove this file.
|
|
651
|
+
|
|
652
|
+
var runtime = regeneratorRuntimeExports();
|
|
653
|
+
var regenerator = runtime;
|
|
654
|
+
|
|
655
|
+
// Copied from https://github.com/facebook/regenerator/blob/main/packages/runtime/runtime.js#L736=
|
|
656
|
+
try {
|
|
657
|
+
regeneratorRuntime = runtime;
|
|
658
|
+
} catch (accidentalStrictMode) {
|
|
659
|
+
if (typeof globalThis === "object") {
|
|
660
|
+
globalThis.regeneratorRuntime = runtime;
|
|
661
|
+
} else {
|
|
662
|
+
Function("r", "regeneratorRuntime = r")(runtime);
|
|
663
|
+
}
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
var _regeneratorRuntime = /*@__PURE__*/getDefaultExportFromCjs(regenerator);
|
|
667
|
+
|
|
668
|
+
function ownKeys$3(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
669
|
+
function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$3(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
670
|
+
var TestMessage = function TestMessage(_ref) {
|
|
671
|
+
var isEmailTemplate = _ref.isEmailTemplate,
|
|
672
|
+
handleSubmitTestTemplate = _ref.handleSubmitTestTemplate,
|
|
673
|
+
isTestMessageLoading = _ref.isTestMessageLoading,
|
|
674
|
+
isTestingTemplateDisabled = _ref.isTestingTemplateDisabled,
|
|
675
|
+
customFields = _ref.customFields;
|
|
676
|
+
var _useState = useState(true),
|
|
677
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
678
|
+
isTestingTemplateRestricted = _useState2[0],
|
|
679
|
+
setIsTestingTemplateRestricted = _useState2[1];
|
|
680
|
+
var _useFormikContext = useFormikContext(),
|
|
681
|
+
values = _useFormikContext.values,
|
|
682
|
+
isValid = _useFormikContext.isValid;
|
|
683
|
+
var _useTranslation = useTranslation(),
|
|
684
|
+
t = _useTranslation.t;
|
|
685
|
+
var handleTestValidation = /*#__PURE__*/function () {
|
|
686
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(event) {
|
|
687
|
+
var value;
|
|
688
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
689
|
+
while (1) switch (_context.prev = _context.next) {
|
|
690
|
+
case 0:
|
|
691
|
+
value = event.target.value;
|
|
692
|
+
_context.prev = 1;
|
|
693
|
+
if (!isEmailTemplate) {
|
|
694
|
+
_context.next = 7;
|
|
695
|
+
break;
|
|
696
|
+
}
|
|
697
|
+
_context.next = 5;
|
|
698
|
+
return SEND_TEST_EMAIL_SCHEMA.validate(value);
|
|
699
|
+
case 5:
|
|
700
|
+
_context.next = 9;
|
|
701
|
+
break;
|
|
702
|
+
case 7:
|
|
703
|
+
_context.next = 9;
|
|
704
|
+
return PHONE_NUMBER_VALIDATION_SCHEMA.validate(value);
|
|
705
|
+
case 9:
|
|
706
|
+
setIsTestingTemplateRestricted(false);
|
|
707
|
+
_context.next = 15;
|
|
708
|
+
break;
|
|
709
|
+
case 12:
|
|
710
|
+
_context.prev = 12;
|
|
711
|
+
_context.t0 = _context["catch"](1);
|
|
712
|
+
setIsTestingTemplateRestricted(true);
|
|
713
|
+
case 15:
|
|
714
|
+
case "end":
|
|
715
|
+
return _context.stop();
|
|
716
|
+
}
|
|
717
|
+
}, _callee, null, [[1, 12]]);
|
|
718
|
+
}));
|
|
719
|
+
return function handleTestValidation(_x) {
|
|
720
|
+
return _ref2.apply(this, arguments);
|
|
721
|
+
};
|
|
722
|
+
}();
|
|
723
|
+
var isTestTemplateButtonDisabled = !isValid || isTestingTemplateDisabled || isTestingTemplateRestricted || isTestMessageLoading;
|
|
724
|
+
var handleKeyDown = function handleKeyDown(event) {
|
|
725
|
+
if (event.key !== "Enter") return;
|
|
726
|
+
event.stopPropagation();
|
|
727
|
+
event.preventDefault();
|
|
728
|
+
!isTestTemplateButtonDisabled && handleSubmitTestTemplate(values);
|
|
729
|
+
};
|
|
730
|
+
return /*#__PURE__*/jsxs(Fragment, {
|
|
731
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
732
|
+
className: "neeto-ui-flex left-0 flex items-start gap-x-2",
|
|
733
|
+
children: [/*#__PURE__*/jsx(Input, _objectSpread$3(_objectSpread$3({
|
|
734
|
+
"data-cy": "message-template-test-input"
|
|
735
|
+
}, !isEmailTemplate && {
|
|
736
|
+
helpText: t("neetoMessageTemplate.template.phoneNumberHelpText")
|
|
737
|
+
}), {}, {
|
|
738
|
+
name: isEmailTemplate ? "testEmailAddress" : "testPhoneNumber",
|
|
739
|
+
placeholder: t(isEmailTemplate ? "neetoMessageTemplate.template.emailAddress" : "neetoMessageTemplate.template.phoneNumber"),
|
|
740
|
+
onKeyDown: handleKeyDown,
|
|
741
|
+
onKeyUp: handleTestValidation
|
|
742
|
+
})), /*#__PURE__*/jsx(Button, {
|
|
743
|
+
"data-cy": "message-template-test-button",
|
|
744
|
+
disabled: isTestTemplateButtonDisabled,
|
|
745
|
+
loading: isTestMessageLoading,
|
|
746
|
+
style: "primary",
|
|
747
|
+
type: "button",
|
|
748
|
+
label: isEmailTemplate ? t("neetoMessageTemplate.template.sendTestEmail") : t("neetoMessageTemplate.template.sendTestSms"),
|
|
749
|
+
onClick: function onClick() {
|
|
750
|
+
return handleSubmitTestTemplate(values);
|
|
751
|
+
}
|
|
752
|
+
})]
|
|
753
|
+
}), !isEmailTemplate && /*#__PURE__*/jsx(Typography, {
|
|
754
|
+
style: "body2",
|
|
755
|
+
children: t("neetoMessageTemplate.sendMessage.testSmsNote")
|
|
756
|
+
}), customFields]
|
|
757
|
+
});
|
|
758
|
+
};
|
|
759
|
+
|
|
760
|
+
function ownKeys$2(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
761
|
+
function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
762
|
+
var Form = function Form(_ref) {
|
|
763
|
+
var onClose = _ref.onClose,
|
|
764
|
+
isEdit = _ref.isEdit,
|
|
765
|
+
_ref$template = _ref.template,
|
|
766
|
+
template = _ref$template === void 0 ? {} : _ref$template,
|
|
767
|
+
createUpdateTemplate = _ref.createUpdateTemplate,
|
|
768
|
+
setInitialFocusField = _ref.setInitialFocusField,
|
|
769
|
+
handleSubmitTestTemplate = _ref.handleSubmitTestTemplate,
|
|
770
|
+
isTestMessageLoading = _ref.isTestMessageLoading,
|
|
771
|
+
shouldIncludeTestTemplate = _ref.shouldIncludeTestTemplate,
|
|
772
|
+
templateVariables = _ref.templateVariables,
|
|
773
|
+
isTestingTemplateDisabled = _ref.isTestingTemplateDisabled,
|
|
774
|
+
customFields = _ref.customFields,
|
|
775
|
+
onMutationSuccess = _ref.onMutationSuccess;
|
|
776
|
+
var _useTranslation = useTranslation(),
|
|
777
|
+
t = _useTranslation.t;
|
|
778
|
+
var editorRef = useRef(null);
|
|
779
|
+
var templateType = useTemplateStore(prop("templateType"));
|
|
780
|
+
var isEmailTemplate = equals(templateType, "email_template");
|
|
781
|
+
var isTestTemplateVisible = includes(templateType, ["sms_template", "email_template"]) && shouldIncludeTestTemplate;
|
|
782
|
+
var _ref2 = isEmailTemplate ? [_objectSpread$2(_objectSpread$2({}, EMAIL_TEMPLATE_INITIAL_VALUES), pick(["name", "body", "subject", "active"], template)), EMAIL_TEMPLATE_FORM_SCHEMA] : [_objectSpread$2(_objectSpread$2({}, SMS_TEMPLATE_INITIAL_VALUES), pick(["name", "body", "active"], template)), SMS_TEMPLATE_FORM_VALIDATION_SCHEMA],
|
|
783
|
+
_ref3 = _slicedToArray(_ref2, 2),
|
|
784
|
+
TEMPLATE_INITIAL_VALUES = _ref3[0],
|
|
785
|
+
TEMPLATE_FORM_SCHEMA = _ref3[1];
|
|
786
|
+
var handleSubmit = function handleSubmit(values) {
|
|
787
|
+
var filteredValues = isEmailTemplate ? omit(["name", "testEmailAddress"], values) : omit(["name", "testPhoneNumber"], values);
|
|
788
|
+
var payload = {
|
|
789
|
+
templateType: templateType,
|
|
790
|
+
name: values.name,
|
|
791
|
+
entity: filteredValues
|
|
792
|
+
};
|
|
793
|
+
createUpdateTemplate({
|
|
794
|
+
isEdit: isEdit,
|
|
795
|
+
payload: payload,
|
|
796
|
+
id: template.id
|
|
797
|
+
}, {
|
|
798
|
+
onSuccess: function onSuccess() {
|
|
799
|
+
onMutationSuccess.apply(void 0, arguments);
|
|
800
|
+
onClose();
|
|
801
|
+
}
|
|
802
|
+
});
|
|
803
|
+
};
|
|
804
|
+
var messageBodyLabel = isEmailTemplate ? t("neetoMessageTemplate.template.emailBody") : t("neetoMessageTemplate.template.smsBody");
|
|
805
|
+
return /*#__PURE__*/jsxs(NeetoUIForm, {
|
|
806
|
+
formProps: {
|
|
807
|
+
noValidate: true,
|
|
808
|
+
className: "flex w-full flex-col gap-y-4 pb-6"
|
|
809
|
+
},
|
|
810
|
+
formikProps: {
|
|
811
|
+
initialValues: TEMPLATE_INITIAL_VALUES,
|
|
812
|
+
validationSchema: TEMPLATE_FORM_SCHEMA,
|
|
813
|
+
validateOnBlur: true,
|
|
814
|
+
validateOnChange: true,
|
|
815
|
+
onSubmit: handleSubmit
|
|
816
|
+
},
|
|
817
|
+
children: [/*#__PURE__*/jsx(Input, {
|
|
818
|
+
required: true,
|
|
819
|
+
label: t("neetoMessageTemplate.template.templateName"),
|
|
820
|
+
name: "name",
|
|
821
|
+
ref: setInitialFocusField
|
|
822
|
+
}), isEmailTemplate && /*#__PURE__*/jsx(FormikAdaptiveInput, {
|
|
823
|
+
required: true,
|
|
824
|
+
label: t("neetoMessageTemplate.template.emailSubject"),
|
|
825
|
+
name: "subject"
|
|
826
|
+
}), /*#__PURE__*/jsx(FormikEditor, {
|
|
827
|
+
hideSlashCommands: true,
|
|
828
|
+
required: true,
|
|
829
|
+
contentClassName: "max-h-40",
|
|
830
|
+
defaults: isEmailTemplate ? undefined : [],
|
|
831
|
+
label: messageBodyLabel,
|
|
832
|
+
name: "body",
|
|
833
|
+
ref: editorRef,
|
|
834
|
+
rows: DEFAULT_EDITOR_ROW_COUNT,
|
|
835
|
+
variables: templateVariables
|
|
836
|
+
}), isTestTemplateVisible && /*#__PURE__*/jsx(TestMessage, {
|
|
837
|
+
customFields: customFields,
|
|
838
|
+
handleSubmitTestTemplate: handleSubmitTestTemplate,
|
|
839
|
+
isEmailTemplate: isEmailTemplate,
|
|
840
|
+
isTestMessageLoading: isTestMessageLoading,
|
|
841
|
+
isTestingTemplateDisabled: isTestingTemplateDisabled
|
|
842
|
+
}), /*#__PURE__*/jsx(Pane.Footer, {
|
|
843
|
+
className: "absolute bottom-0 left-0",
|
|
844
|
+
children: /*#__PURE__*/jsx(ActionBlock, {
|
|
845
|
+
cancelButtonProps: {
|
|
846
|
+
"data-cy": "message-template-reset-button",
|
|
847
|
+
onClick: onClose
|
|
848
|
+
},
|
|
849
|
+
submitButtonProps: {
|
|
850
|
+
"data-cy": "message-template-submit-button"
|
|
851
|
+
}
|
|
852
|
+
})
|
|
853
|
+
})]
|
|
854
|
+
});
|
|
855
|
+
};
|
|
856
|
+
|
|
857
|
+
var AddEdit = function AddEdit(_ref) {
|
|
858
|
+
var onClose = _ref.onClose,
|
|
859
|
+
createUpdateTemplate = _ref.createUpdateTemplate,
|
|
860
|
+
manageTemplatePane = _ref.manageTemplatePane,
|
|
861
|
+
isTestMessageLoading = _ref.isTestMessageLoading,
|
|
862
|
+
handleSubmitTestTemplate = _ref.handleSubmitTestTemplate,
|
|
863
|
+
shouldIncludeTestTemplate = _ref.shouldIncludeTestTemplate,
|
|
864
|
+
addText = _ref.addText,
|
|
865
|
+
editText = _ref.editText,
|
|
866
|
+
templateVariables = _ref.templateVariables,
|
|
867
|
+
isTestingTemplateDisabled = _ref.isTestingTemplateDisabled,
|
|
868
|
+
customFields = _ref.customFields,
|
|
869
|
+
onMutationSuccess = _ref.onMutationSuccess;
|
|
870
|
+
var initialFocusField = useRef();
|
|
871
|
+
var setInitialFocusField = function setInitialFocusField(fieldRef) {
|
|
872
|
+
return initialFocusField.current = fieldRef;
|
|
873
|
+
};
|
|
874
|
+
var isOpen = manageTemplatePane.isOpen,
|
|
875
|
+
isEdit = manageTemplatePane.isEdit,
|
|
876
|
+
template = manageTemplatePane.template;
|
|
877
|
+
var label = isEdit ? editText : addText;
|
|
878
|
+
return /*#__PURE__*/jsxs(Pane, {
|
|
879
|
+
isOpen: isOpen,
|
|
880
|
+
onClose: onClose,
|
|
881
|
+
initialFocusRef: initialFocusField,
|
|
882
|
+
children: [/*#__PURE__*/jsx(Pane.Header, {
|
|
883
|
+
children: /*#__PURE__*/jsx(Typography, {
|
|
884
|
+
style: "h2",
|
|
885
|
+
weight: "semibold",
|
|
886
|
+
children: label
|
|
887
|
+
})
|
|
888
|
+
}), /*#__PURE__*/jsx(Pane.Body, {
|
|
889
|
+
children: /*#__PURE__*/jsx(Form, {
|
|
890
|
+
createUpdateTemplate: createUpdateTemplate,
|
|
891
|
+
customFields: customFields,
|
|
892
|
+
handleSubmitTestTemplate: handleSubmitTestTemplate,
|
|
893
|
+
isEdit: isEdit,
|
|
894
|
+
isTestMessageLoading: isTestMessageLoading,
|
|
895
|
+
isTestingTemplateDisabled: isTestingTemplateDisabled,
|
|
896
|
+
onClose: onClose,
|
|
897
|
+
onMutationSuccess: onMutationSuccess,
|
|
898
|
+
setInitialFocusField: setInitialFocusField,
|
|
899
|
+
shouldIncludeTestTemplate: shouldIncludeTestTemplate,
|
|
900
|
+
template: template,
|
|
901
|
+
templateVariables: templateVariables
|
|
902
|
+
})
|
|
903
|
+
})]
|
|
904
|
+
});
|
|
905
|
+
};
|
|
906
|
+
|
|
907
|
+
var useFilters = function useFilters() {
|
|
908
|
+
var _useState = useState(DEFAULT_PAGE_PROPERTIES),
|
|
909
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
910
|
+
pageProperties = _useState2[0],
|
|
911
|
+
setPageProperties = _useState2[1];
|
|
912
|
+
var _useQueryParams = useQueryParams(),
|
|
913
|
+
_useQueryParams$searc = _useQueryParams.searchTerm,
|
|
914
|
+
searchTerm = _useQueryParams$searc === void 0 ? "" : _useQueryParams$searc;
|
|
915
|
+
var filterColumns = buildTableColumnData().filter(prop("node"));
|
|
916
|
+
var searchKeywordProps = {
|
|
917
|
+
key: "search_term",
|
|
918
|
+
node: "name",
|
|
919
|
+
value: searchTerm,
|
|
920
|
+
setValue: noop
|
|
921
|
+
};
|
|
922
|
+
var _useState3 = useState(function () {
|
|
923
|
+
return buildFiltersFromURL([].concat(_toConsumableArray(filterColumns), [searchKeywordProps]));
|
|
924
|
+
}),
|
|
925
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
926
|
+
filters = _useState4[0],
|
|
927
|
+
setFilters = _useState4[1];
|
|
928
|
+
return {
|
|
929
|
+
filterColumns: filterColumns,
|
|
930
|
+
searchKeywordProps: searchKeywordProps,
|
|
931
|
+
searchTerm: searchTerm,
|
|
932
|
+
filters: filters,
|
|
933
|
+
setFilters: setFilters,
|
|
934
|
+
pageProperties: pageProperties,
|
|
935
|
+
setPageProperties: setPageProperties
|
|
936
|
+
};
|
|
937
|
+
};
|
|
938
|
+
|
|
939
|
+
var useTemplates = function useTemplates(_ref) {
|
|
940
|
+
var type = _ref.type,
|
|
941
|
+
ownerId = _ref.ownerId,
|
|
942
|
+
filters = _ref.filters,
|
|
943
|
+
pageProperties = _ref.pageProperties;
|
|
944
|
+
var pageIndex = pageProperties.index,
|
|
945
|
+
pageSize = pageProperties.size;
|
|
946
|
+
var templateParams = {
|
|
947
|
+
page: pageIndex,
|
|
948
|
+
pageSize: pageSize,
|
|
949
|
+
filters: filters,
|
|
950
|
+
templateType: MESSAGE_TEMPLATES[type].value,
|
|
951
|
+
ownerId: isEmpty(ownerId) ? undefined : ownerId
|
|
952
|
+
};
|
|
953
|
+
var _useFetchTemplates = useFetchTemplates(templateParams),
|
|
954
|
+
_useFetchTemplates$da = _useFetchTemplates.data,
|
|
955
|
+
templatesData = _useFetchTemplates$da === void 0 ? {} : _useFetchTemplates$da,
|
|
956
|
+
isLoadingTemplates = _useFetchTemplates.isLoading,
|
|
957
|
+
isFetching = _useFetchTemplates.isFetching;
|
|
958
|
+
var _useCreateTemplate = useCreateTemplate(ownerId),
|
|
959
|
+
create = _useCreateTemplate.mutate;
|
|
960
|
+
var _useUpdateTemplate = useUpdateTemplate(ownerId),
|
|
961
|
+
update = _useUpdateTemplate.mutate;
|
|
962
|
+
var createUpdateTemplate = function createUpdateTemplate(_ref2, options) {
|
|
963
|
+
var isEdit = _ref2.isEdit,
|
|
964
|
+
payload = _ref2.payload,
|
|
965
|
+
_ref2$id = _ref2.id,
|
|
966
|
+
id = _ref2$id === void 0 ? null : _ref2$id;
|
|
967
|
+
return isEdit ? update({
|
|
968
|
+
id: id,
|
|
969
|
+
payload: payload
|
|
970
|
+
}, options) : create(payload, options);
|
|
971
|
+
};
|
|
972
|
+
var isLoaderVisible = isLoadingTemplates || isFetching;
|
|
973
|
+
return {
|
|
974
|
+
templatesData: templatesData,
|
|
975
|
+
isLoading: isLoaderVisible,
|
|
976
|
+
createUpdateTemplate: createUpdateTemplate
|
|
977
|
+
};
|
|
978
|
+
};
|
|
979
|
+
|
|
980
|
+
function ownKeys$1(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
981
|
+
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$1(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
982
|
+
var List = function List(_ref) {
|
|
983
|
+
var setManageTemplatePane = _ref.setManageTemplatePane,
|
|
984
|
+
templatesData = _ref.templatesData,
|
|
985
|
+
isLoading = _ref.isLoading,
|
|
986
|
+
manageTemplatePane = _ref.manageTemplatePane,
|
|
987
|
+
labelSingular = _ref.labelSingular,
|
|
988
|
+
setPageProperties = _ref.setPageProperties,
|
|
989
|
+
pageProperties = _ref.pageProperties,
|
|
990
|
+
label = _ref.label,
|
|
991
|
+
addText = _ref.addText,
|
|
992
|
+
isFilterApplied = _ref.isFilterApplied,
|
|
993
|
+
ownerId = _ref.ownerId,
|
|
994
|
+
type = _ref.type,
|
|
995
|
+
onMutationSuccess = _ref.onMutationSuccess,
|
|
996
|
+
helpDocUrl = _ref.helpDocUrl;
|
|
997
|
+
var _useTranslation = useTranslation(),
|
|
998
|
+
t = _useTranslation.t;
|
|
999
|
+
var _useDeleteTemplate = useDeleteTemplate(ownerId),
|
|
1000
|
+
deleteTemplate = _useDeleteTemplate.mutate,
|
|
1001
|
+
isDeleting = _useDeleteTemplate.isPending;
|
|
1002
|
+
var templates = templatesData.templates,
|
|
1003
|
+
totalCount = templatesData.totalCount;
|
|
1004
|
+
var template = manageTemplatePane.template,
|
|
1005
|
+
isDelete = manageTemplatePane.isDelete;
|
|
1006
|
+
var pageIndex = pageProperties.index,
|
|
1007
|
+
pageSize = pageProperties.size;
|
|
1008
|
+
var isSms = type === "sms";
|
|
1009
|
+
var typeLabelSingular = isSms ? labelSingular : labelSingular.toLowerCase();
|
|
1010
|
+
var emptyStateLabel = isSms ? label : label.toLowerCase();
|
|
1011
|
+
var noDataProps = _objectSpread$1(_objectSpread$1({}, !isFilterApplied && {
|
|
1012
|
+
primaryButtonProps: {
|
|
1013
|
+
label: addText,
|
|
1014
|
+
onClick: function onClick() {
|
|
1015
|
+
return setManageTemplatePane(assoc("isOpen", true));
|
|
1016
|
+
}
|
|
1017
|
+
},
|
|
1018
|
+
helpText: /*#__PURE__*/jsx(Trans, {
|
|
1019
|
+
i18nKey: "neetoMessageTemplate.template.linkToHelpArticle",
|
|
1020
|
+
values: {
|
|
1021
|
+
entity: label
|
|
1022
|
+
},
|
|
1023
|
+
components: {
|
|
1024
|
+
Link: /*#__PURE__*/jsx(Button, {
|
|
1025
|
+
className: "underline",
|
|
1026
|
+
href: helpDocUrl,
|
|
1027
|
+
style: "link",
|
|
1028
|
+
target: "_blank"
|
|
1029
|
+
})
|
|
1030
|
+
}
|
|
1031
|
+
})
|
|
1032
|
+
}), {}, {
|
|
1033
|
+
title: isFilterApplied ? t("neetoMessageTemplate.template.filtersEmptyState", {
|
|
1034
|
+
type: emptyStateLabel
|
|
1035
|
+
}) : t("neetoMessageTemplate.template.emptyState", {
|
|
1036
|
+
type: emptyStateLabel
|
|
1037
|
+
})
|
|
1038
|
+
});
|
|
1039
|
+
var handleDelete = function handleDelete() {
|
|
1040
|
+
deleteTemplate(template.id, {
|
|
1041
|
+
onSuccess: onMutationSuccess,
|
|
1042
|
+
onSettled: function onSettled() {
|
|
1043
|
+
setManageTemplatePane(assoc("isDelete", false));
|
|
1044
|
+
}
|
|
1045
|
+
});
|
|
1046
|
+
};
|
|
1047
|
+
return /*#__PURE__*/jsxs(Fragment, {
|
|
1048
|
+
children: [!isEmpty(templates) ? /*#__PURE__*/jsx(TableWrapper, {
|
|
1049
|
+
hasPagination: totalCount > pageSize,
|
|
1050
|
+
children: /*#__PURE__*/jsx(Table, {
|
|
1051
|
+
totalCount: totalCount,
|
|
1052
|
+
fixedHeight: true,
|
|
1053
|
+
currentPageNumber: pageIndex,
|
|
1054
|
+
defaultPageSize: pageSize,
|
|
1055
|
+
loading: isLoading,
|
|
1056
|
+
rowData: templates,
|
|
1057
|
+
scroll: {
|
|
1058
|
+
x: "100%"
|
|
1059
|
+
},
|
|
1060
|
+
columnData: buildTableColumnData(setManageTemplatePane, ownerId, onMutationSuccess),
|
|
1061
|
+
handlePageChange: function handlePageChange(index, size) {
|
|
1062
|
+
return setPageProperties({
|
|
1063
|
+
index: index,
|
|
1064
|
+
size: size
|
|
1065
|
+
});
|
|
1066
|
+
}
|
|
1067
|
+
})
|
|
1068
|
+
}) : /*#__PURE__*/jsx("div", {
|
|
1069
|
+
className: "flex h-full w-full items-center justify-center",
|
|
1070
|
+
children: /*#__PURE__*/jsx(NoData, _objectSpread$1({}, noDataProps))
|
|
1071
|
+
}), /*#__PURE__*/jsx(Alert, {
|
|
1072
|
+
isOpen: isDelete,
|
|
1073
|
+
isSubmitting: isDeleting,
|
|
1074
|
+
submitButtonLabel: t("neetoMessageTemplate.template.delete"),
|
|
1075
|
+
message: /*#__PURE__*/jsx(Trans, {
|
|
1076
|
+
i18nKey: "neetoMessageTemplate.template.templateDeleteConfirmation",
|
|
1077
|
+
values: {
|
|
1078
|
+
name: template.name
|
|
1079
|
+
}
|
|
1080
|
+
}),
|
|
1081
|
+
title: t("neetoMessageTemplate.template.deleteTemplate", {
|
|
1082
|
+
label: typeLabelSingular
|
|
1083
|
+
}),
|
|
1084
|
+
onClose: function onClose() {
|
|
1085
|
+
return setManageTemplatePane(assoc("isDelete", false));
|
|
1086
|
+
},
|
|
1087
|
+
onSubmit: handleDelete
|
|
1088
|
+
})]
|
|
1089
|
+
});
|
|
1090
|
+
};
|
|
1091
|
+
|
|
1092
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1093
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
1094
|
+
var MessageTemplates = function MessageTemplates(_ref) {
|
|
1095
|
+
var _helpPopoverProps$hel;
|
|
1096
|
+
var _ref$breadcrumbs = _ref.breadcrumbs,
|
|
1097
|
+
breadcrumbs = _ref$breadcrumbs === void 0 ? [] : _ref$breadcrumbs,
|
|
1098
|
+
_ref$type = _ref.type,
|
|
1099
|
+
type = _ref$type === void 0 ? "" : _ref$type,
|
|
1100
|
+
_ref$handleSubmitTest = _ref.handleSubmitTestTemplate,
|
|
1101
|
+
handleSubmitTestTemplate = _ref$handleSubmitTest === void 0 ? noop : _ref$handleSubmitTest,
|
|
1102
|
+
_ref$isTestMessageLoa = _ref.isTestMessageLoading,
|
|
1103
|
+
isTestMessageLoading = _ref$isTestMessageLoa === void 0 ? false : _ref$isTestMessageLoa,
|
|
1104
|
+
_ref$shouldIncludeTes = _ref.shouldIncludeTestTemplate,
|
|
1105
|
+
shouldIncludeTestTemplate = _ref$shouldIncludeTes === void 0 ? true : _ref$shouldIncludeTes,
|
|
1106
|
+
_ref$templateVariable = _ref.templateVariables,
|
|
1107
|
+
templateVariables = _ref$templateVariable === void 0 ? {} : _ref$templateVariable,
|
|
1108
|
+
_ref$ownerId = _ref.ownerId,
|
|
1109
|
+
ownerId = _ref$ownerId === void 0 ? "" : _ref$ownerId,
|
|
1110
|
+
_ref$isTestingTemplat = _ref.isTestingTemplateDisabled,
|
|
1111
|
+
isTestingTemplateDisabled = _ref$isTestingTemplat === void 0 ? false : _ref$isTestingTemplat,
|
|
1112
|
+
_ref$manageTemplatesP = _ref.manageTemplatesPaneCustomFields,
|
|
1113
|
+
manageTemplatesPaneCustomFields = _ref$manageTemplatesP === void 0 ? null : _ref$manageTemplatesP,
|
|
1114
|
+
_ref$onMutationSucces = _ref.onMutationSuccess,
|
|
1115
|
+
onMutationSuccess = _ref$onMutationSucces === void 0 ? noop : _ref$onMutationSucces,
|
|
1116
|
+
_ref$helpPopoverProps = _ref.helpPopoverProps,
|
|
1117
|
+
helpPopoverProps = _ref$helpPopoverProps === void 0 ? {} : _ref$helpPopoverProps;
|
|
1118
|
+
var _useState = useState(MESSAGE_TEMPLATE_INITIAL_STATE),
|
|
1119
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1120
|
+
manageTemplatePane = _useState2[0],
|
|
1121
|
+
setManageTemplatePane = _useState2[1];
|
|
1122
|
+
var _useState3 = useState(false),
|
|
1123
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
1124
|
+
isFilterPaneOpen = _useState4[0],
|
|
1125
|
+
setIsFilterPaneOpen = _useState4[1];
|
|
1126
|
+
var _useTranslation = useTranslation(),
|
|
1127
|
+
t = _useTranslation.t;
|
|
1128
|
+
var _useFilters = useFilters(),
|
|
1129
|
+
searchKeywordProps = _useFilters.searchKeywordProps,
|
|
1130
|
+
filterColumns = _useFilters.filterColumns,
|
|
1131
|
+
searchTerm = _useFilters.searchTerm,
|
|
1132
|
+
filters = _useFilters.filters,
|
|
1133
|
+
setFilters = _useFilters.setFilters,
|
|
1134
|
+
pageProperties = _useFilters.pageProperties,
|
|
1135
|
+
setPageProperties = _useFilters.setPageProperties;
|
|
1136
|
+
var _useTemplates = useTemplates({
|
|
1137
|
+
type: type,
|
|
1138
|
+
ownerId: ownerId,
|
|
1139
|
+
filters: filters,
|
|
1140
|
+
pageProperties: pageProperties
|
|
1141
|
+
}),
|
|
1142
|
+
isLoading = _useTemplates.isLoading,
|
|
1143
|
+
templatesData = _useTemplates.templatesData,
|
|
1144
|
+
createUpdateTemplate = _useTemplates.createUpdateTemplate;
|
|
1145
|
+
var setTemplateState = useTemplateStore(prop("setTemplateState"));
|
|
1146
|
+
var _MESSAGE_TEMPLATES$ty = MESSAGE_TEMPLATES[type],
|
|
1147
|
+
label = _MESSAGE_TEMPLATES$ty.label,
|
|
1148
|
+
value = _MESSAGE_TEMPLATES$ty.value,
|
|
1149
|
+
addText = _MESSAGE_TEMPLATES$ty.addText,
|
|
1150
|
+
labelSingular = _MESSAGE_TEMPLATES$ty.labelSingular,
|
|
1151
|
+
editText = _MESSAGE_TEMPLATES$ty.editText;
|
|
1152
|
+
var isFilterApplied = isNotEmpty(filters) || isNotEmpty(searchTerm);
|
|
1153
|
+
var handleActionClick = function handleActionClick() {
|
|
1154
|
+
return setManageTemplatePane(_objectSpread(_objectSpread({}, MESSAGE_TEMPLATE_INITIAL_STATE), {}, {
|
|
1155
|
+
isOpen: true
|
|
1156
|
+
}));
|
|
1157
|
+
};
|
|
1158
|
+
var handleChange = function handleChange(filters) {
|
|
1159
|
+
setFilters(filters);
|
|
1160
|
+
setPageProperties(DEFAULT_PAGE_PROPERTIES);
|
|
1161
|
+
};
|
|
1162
|
+
var templatesCount = (templatesData === null || templatesData === void 0 ? void 0 : templatesData.totalCount) || 0;
|
|
1163
|
+
useEffect(function () {
|
|
1164
|
+
setTemplateState({
|
|
1165
|
+
templateType: value
|
|
1166
|
+
});
|
|
1167
|
+
}, [value]);
|
|
1168
|
+
var shouldShowTemplatesCount = !isLoading && (isFilterApplied || templatesCount > 0);
|
|
1169
|
+
var helpDocUrl = (helpPopoverProps === null || helpPopoverProps === void 0 || (_helpPopoverProps$hel = helpPopoverProps.helpLinkProps) === null || _helpPopoverProps$hel === void 0 ? void 0 : _helpPopoverProps$hel.href) || "";
|
|
1170
|
+
return /*#__PURE__*/jsxs(Container, {
|
|
1171
|
+
children: [/*#__PURE__*/jsx(NeetoHeader, {
|
|
1172
|
+
breadcrumbs: breadcrumbs,
|
|
1173
|
+
size: "small",
|
|
1174
|
+
actionBlock: /*#__PURE__*/jsx(Button, {
|
|
1175
|
+
"data-cy": "add-".concat(hyphenate(value), "-button"),
|
|
1176
|
+
label: addText,
|
|
1177
|
+
onClick: handleActionClick
|
|
1178
|
+
}),
|
|
1179
|
+
searchProps: shouldShowTemplatesCount && renderSearchProps(label, value),
|
|
1180
|
+
title: /*#__PURE__*/jsxs("span", {
|
|
1181
|
+
className: "flex",
|
|
1182
|
+
children: [label, /*#__PURE__*/jsx(HelpPopover, _objectSpread(_objectSpread({
|
|
1183
|
+
className: "ml-2 self-center"
|
|
1184
|
+
}, helpPopoverProps), {}, {
|
|
1185
|
+
title: (helpPopoverProps === null || helpPopoverProps === void 0 ? void 0 : helpPopoverProps.title) || label
|
|
1186
|
+
}))]
|
|
1187
|
+
})
|
|
1188
|
+
}), /*#__PURE__*/jsx(SubHeader, {
|
|
1189
|
+
leftActionBlock: shouldShowTemplatesCount && /*#__PURE__*/jsx(Typography, {
|
|
1190
|
+
component: "h4",
|
|
1191
|
+
children: t("neetoMessageTemplate.template.messageTemplatesWithCount", {
|
|
1192
|
+
type: MESSAGE_TYPES[type],
|
|
1193
|
+
count: templatesCount
|
|
1194
|
+
})
|
|
1195
|
+
}),
|
|
1196
|
+
rightActionBlock: /*#__PURE__*/jsx(SubHeader.RightBlock, {
|
|
1197
|
+
dataProps: {
|
|
1198
|
+
totalCount: isFilterApplied ? null : templatesCount
|
|
1199
|
+
},
|
|
1200
|
+
filterProps: {
|
|
1201
|
+
columns: filterColumns,
|
|
1202
|
+
isOpen: isFilterPaneOpen,
|
|
1203
|
+
keyword: searchKeywordProps,
|
|
1204
|
+
setIsOpen: setIsFilterPaneOpen,
|
|
1205
|
+
onChange: handleChange
|
|
1206
|
+
}
|
|
1207
|
+
})
|
|
1208
|
+
}), /*#__PURE__*/jsx(Bar, {
|
|
1209
|
+
columns: filterColumns,
|
|
1210
|
+
keyword: searchKeywordProps,
|
|
1211
|
+
setIsPaneOpen: setIsFilterPaneOpen,
|
|
1212
|
+
onChange: handleChange
|
|
1213
|
+
}), /*#__PURE__*/jsx(List, {
|
|
1214
|
+
addText: addText,
|
|
1215
|
+
helpDocUrl: helpDocUrl,
|
|
1216
|
+
isFilterApplied: isFilterApplied,
|
|
1217
|
+
isLoading: isLoading,
|
|
1218
|
+
label: label,
|
|
1219
|
+
labelSingular: labelSingular,
|
|
1220
|
+
manageTemplatePane: manageTemplatePane,
|
|
1221
|
+
onMutationSuccess: onMutationSuccess,
|
|
1222
|
+
ownerId: ownerId,
|
|
1223
|
+
pageProperties: pageProperties,
|
|
1224
|
+
setManageTemplatePane: setManageTemplatePane,
|
|
1225
|
+
setPageProperties: setPageProperties,
|
|
1226
|
+
templatesData: templatesData,
|
|
1227
|
+
type: type
|
|
1228
|
+
}), /*#__PURE__*/jsx(AddEdit, {
|
|
1229
|
+
addText: addText,
|
|
1230
|
+
createUpdateTemplate: createUpdateTemplate,
|
|
1231
|
+
editText: editText,
|
|
1232
|
+
handleSubmitTestTemplate: handleSubmitTestTemplate,
|
|
1233
|
+
isTestMessageLoading: isTestMessageLoading,
|
|
1234
|
+
isTestingTemplateDisabled: isTestingTemplateDisabled,
|
|
1235
|
+
manageTemplatePane: manageTemplatePane,
|
|
1236
|
+
onMutationSuccess: onMutationSuccess,
|
|
1237
|
+
shouldIncludeTestTemplate: shouldIncludeTestTemplate,
|
|
1238
|
+
templateVariables: templateVariables,
|
|
1239
|
+
customFields: manageTemplatesPaneCustomFields,
|
|
1240
|
+
onClose: function onClose() {
|
|
1241
|
+
return setManageTemplatePane(assoc("isOpen", false));
|
|
1242
|
+
}
|
|
1243
|
+
})]
|
|
1244
|
+
});
|
|
1245
|
+
};
|
|
1246
|
+
|
|
1247
|
+
export { MessageTemplates as default };
|
|
1248
|
+
//# sourceMappingURL=MessageTemplates.js.map
|