@bigbinary/neeto-message-templates-frontend 0.8.0-beta1 → 1.0.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/index.cjs.js CHANGED
@@ -23,7 +23,7 @@ var require$$0 = require('util');
23
23
  var zustand = require('zustand');
24
24
  var jsxRuntime = require('react/jsx-runtime');
25
25
  var Pane = require('@bigbinary/neetoui/Pane');
26
- var neetoEditor = require('@bigbinary/neeto-editor');
26
+ var FormikEditor = require('@bigbinary/neeto-editor/FormikEditor');
27
27
  var NeetoUIForm = require('@bigbinary/neetoui/formik/Form');
28
28
  var Input = require('@bigbinary/neetoui/formik/Input');
29
29
  var ActionBlock = require('@bigbinary/neetoui/formik/ActionBlock');
@@ -39,7 +39,7 @@ var Spinner = require('@bigbinary/neetoui/Spinner');
39
39
  var Select = require('@bigbinary/neetoui/Select');
40
40
  var Textarea$1 = require('@bigbinary/neetoui/Textarea');
41
41
  var Select$1 = require('@bigbinary/neetoui/formik/Select');
42
- var neetoIcons = require('@bigbinary/neeto-icons');
42
+ var Delete = require('@bigbinary/neeto-icons/Delete');
43
43
  var Label = require('@bigbinary/neetoui/Label');
44
44
 
45
45
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
@@ -72,6 +72,7 @@ var MoreDropdown__default = /*#__PURE__*/_interopDefaultLegacy(MoreDropdown);
72
72
  var axios__default = /*#__PURE__*/_interopDefaultLegacy(axios);
73
73
  var require$$0__default = /*#__PURE__*/_interopDefaultLegacy(require$$0);
74
74
  var Pane__default = /*#__PURE__*/_interopDefaultLegacy(Pane);
75
+ var FormikEditor__default = /*#__PURE__*/_interopDefaultLegacy(FormikEditor);
75
76
  var NeetoUIForm__default = /*#__PURE__*/_interopDefaultLegacy(NeetoUIForm);
76
77
  var Input__default = /*#__PURE__*/_interopDefaultLegacy(Input);
77
78
  var ActionBlock__default = /*#__PURE__*/_interopDefaultLegacy(ActionBlock);
@@ -85,6 +86,7 @@ var Spinner__default = /*#__PURE__*/_interopDefaultLegacy(Spinner);
85
86
  var Select__default = /*#__PURE__*/_interopDefaultLegacy(Select);
86
87
  var Textarea__default$1 = /*#__PURE__*/_interopDefaultLegacy(Textarea$1);
87
88
  var Select__default$1 = /*#__PURE__*/_interopDefaultLegacy(Select$1);
89
+ var Delete__default = /*#__PURE__*/_interopDefaultLegacy(Delete);
88
90
  var Label__default = /*#__PURE__*/_interopDefaultLegacy(Label);
89
91
 
90
92
  function _typeof$1(o) {
@@ -2352,7 +2354,7 @@ var useCreateTemplate = function useCreateTemplate(ownerId, options) {
2352
2354
  ownerId: ownerIdValue(ownerId)
2353
2355
  });
2354
2356
  }, _objectSpread$d({
2355
- keysToInvalidate: [QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]
2357
+ keysToInvalidate: [[QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]]
2356
2358
  }, options));
2357
2359
  };
2358
2360
  var useUpdateTemplate = function useUpdateTemplate(ownerId) {
@@ -2365,7 +2367,7 @@ var useUpdateTemplate = function useUpdateTemplate(ownerId) {
2365
2367
  ownerId: ownerIdValue(ownerId)
2366
2368
  });
2367
2369
  }, {
2368
- keysToInvalidate: [QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]
2370
+ keysToInvalidate: [[QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]]
2369
2371
  });
2370
2372
  };
2371
2373
  var useDeleteTemplate = function useDeleteTemplate(ownerId) {
@@ -2375,7 +2377,7 @@ var useDeleteTemplate = function useDeleteTemplate(ownerId) {
2375
2377
  ownerId: ownerIdValue(ownerId)
2376
2378
  });
2377
2379
  }, {
2378
- keysToInvalidate: [QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]
2380
+ keysToInvalidate: [[QUERY_KEYS.NEETO_MESSAGE_TEMPLATES]]
2379
2381
  });
2380
2382
  };
2381
2383
 
@@ -3159,7 +3161,7 @@ var Form$1 = function Form(_ref) {
3159
3161
  required: true,
3160
3162
  label: t("neetoMessageTemplate.template.emailSubject"),
3161
3163
  name: "subject"
3162
- }), /*#__PURE__*/jsxRuntime.jsx(neetoEditor.FormikEditor, {
3164
+ }), /*#__PURE__*/jsxRuntime.jsx(FormikEditor__default["default"], {
3163
3165
  hideSlashCommands: true,
3164
3166
  required: true,
3165
3167
  contentClassName: "max-h-40",
@@ -3699,13 +3701,14 @@ var EmailAndSms = function EmailAndSms(_ref) {
3699
3701
  var setValues = _ref4.setValues,
3700
3702
  values = _ref4.values;
3701
3703
  var handleTemplateChange = function handleTemplateChange(value) {
3704
+ var _editorRef$current;
3702
3705
  if (!value) return;
3703
3706
  var customFieldValues = ramda.omit(initialValueKeys, values);
3704
3707
  var template = neetoCist.findBy({
3705
3708
  id: value === null || value === void 0 ? void 0 : value.value
3706
3709
  }, templates);
3707
3710
  setValues(_objectSpread$5(_objectSpread$5({}, template), customFieldValues));
3708
- editorRef.current.editor.commands.setContent(template.body);
3711
+ (_editorRef$current = editorRef.current) === null || _editorRef$current === void 0 || (_editorRef$current = _editorRef$current.editor) === null || _editorRef$current === void 0 || (_editorRef$current = _editorRef$current.commands) === null || _editorRef$current === void 0 || _editorRef$current.setContent(template.body);
3709
3712
  };
3710
3713
  return /*#__PURE__*/jsxRuntime.jsxs(jsxRuntime.Fragment, {
3711
3714
  children: [/*#__PURE__*/jsxRuntime.jsx(Select__default["default"], {
@@ -3723,7 +3726,7 @@ var EmailAndSms = function EmailAndSms(_ref) {
3723
3726
  required: true,
3724
3727
  label: t("neetoMessageTemplate.template.subject"),
3725
3728
  name: "subject"
3726
- }), /*#__PURE__*/jsxRuntime.jsx(neetoEditor.FormikEditor, {
3729
+ }), /*#__PURE__*/jsxRuntime.jsx(FormikEditor__default["default"], {
3727
3730
  hideSlashCommands: true,
3728
3731
  required: true,
3729
3732
  contentClassName: "max-h-40",
@@ -4064,14 +4067,17 @@ var KeyValuePairs = reactUtils.withT(function (_ref) {
4064
4067
  className: "flex h-8 space-x-3",
4065
4068
  children: [/*#__PURE__*/jsxRuntime.jsx(Input__default["default"], {
4066
4069
  className: "w-2/5",
4070
+ "data-cy": "key-input-".concat(index),
4067
4071
  name: "".concat(name, ".").concat(index, ".key"),
4068
4072
  placeholder: t("neetoMessageTemplate.api.key")
4069
4073
  }), /*#__PURE__*/jsxRuntime.jsx(Input__default["default"], {
4070
4074
  className: "w-3/5",
4075
+ "data-cy": "value-input-".concat(index),
4071
4076
  name: "".concat(name, ".").concat(index, ".value"),
4072
4077
  placeholder: t("neetoMessageTemplate.api.value"),
4073
4078
  suffix: showDeleteButton && /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
4074
- icon: neetoIcons.Delete,
4079
+ "data-cy": "delete-key-value-pair-".concat(index),
4080
+ icon: Delete__default["default"],
4075
4081
  size: "small",
4076
4082
  style: "text",
4077
4083
  onClick: function onClick() {
@@ -4086,6 +4092,7 @@ var KeyValuePairs = reactUtils.withT(function (_ref) {
4086
4092
  }, index);
4087
4093
  }), /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
4088
4094
  className: "w-full justify-center",
4095
+ "data-cy": "add-key-value-pair-button",
4089
4096
  label: t("neetoMessageTemplate.api.addKeyValuePair"),
4090
4097
  style: "secondary",
4091
4098
  onClick: function onClick() {
@@ -4126,30 +4133,37 @@ var buildTableColumnData = function buildTableColumnData(_ref) {
4126
4133
  return /*#__PURE__*/jsxRuntime.jsxs("div", {
4127
4134
  className: "flex items-center justify-between gap-x-3",
4128
4135
  children: [/*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
4136
+ "data-cy": "api-template-name-link",
4129
4137
  label: name,
4130
4138
  style: "link",
4131
4139
  onClick: function onClick() {
4132
4140
  return handleOpenEditPane(apiTemplate);
4133
4141
  }
4134
4142
  }), /*#__PURE__*/jsxRuntime.jsx(MoreDropdown__default["default"], {
4143
+ dropdownButtonProps: {
4144
+ "data-cy": "api-template-dropdown"
4145
+ },
4135
4146
  dropdownProps: {
4136
4147
  strategy: "fixed"
4137
4148
  },
4138
4149
  menuItems: [{
4139
4150
  key: "edit",
4140
4151
  label: i18next.t("neetoMessageTemplate.template.edit"),
4152
+ "data-cy": "api-template-button-edit-button",
4141
4153
  onClick: function onClick() {
4142
4154
  return handleOpenEditPane(apiTemplate);
4143
4155
  }
4144
4156
  }, {
4145
4157
  key: "status",
4146
4158
  label: ramda.equals(apiTemplate.status, TEMPLATE_STATUS.ACTIVE) ? i18next.t("neetoMessageTemplate.template.markAsInactive") : i18next.t("neetoMessageTemplate.template.markAsActive"),
4159
+ "data-cy": "api-template-button-status-button",
4147
4160
  onClick: function onClick() {
4148
4161
  return handleMarkAsActiveOrInactive(apiTemplate);
4149
4162
  }
4150
4163
  }, {
4151
4164
  key: "delete",
4152
4165
  label: i18next.t("neetoMessageTemplate.template.delete"),
4166
+ "data-cy": "api-template-button-delete-button",
4153
4167
  onClick: function onClick() {
4154
4168
  return handleOpenDeleteAlert(apiTemplate);
4155
4169
  }
@@ -4393,13 +4407,15 @@ var ApiTemplates = function ApiTemplates(_ref) {
4393
4407
  breadcrumbs: breadcrumbs,
4394
4408
  size: "small",
4395
4409
  actionBlock: /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
4410
+ "data-cy": "add-api-templates-button",
4396
4411
  label: t("neetoMessageTemplate.api.addApiTemplate"),
4397
4412
  onClick: function onClick() {
4398
4413
  return setIsFormPaneOpen(true);
4399
4414
  }
4400
4415
  }),
4401
4416
  searchProps: {
4402
- placeholder: t("neetoMessageTemplate.template.searchApiTemplates")
4417
+ placeholder: t("neetoMessageTemplate.template.searchApiTemplates"),
4418
+ "data-cy": "api-templates-search-input"
4403
4419
  },
4404
4420
  title: /*#__PURE__*/jsxRuntime.jsxs("span", {
4405
4421
  className: "flex",
@@ -4505,6 +4521,10 @@ var SEND_TO_API_FORM_VALIDATION_SCHEMA = yup__namespace.object({
4505
4521
  }))
4506
4522
  });
4507
4523
 
4524
+ var formatAdditionalData = function formatAdditionalData(additionalData) {
4525
+ return neetoCist.isPresent(additionalData) ? additionalData : [ADDITIONAL_DATA_INITIAL_VALUE];
4526
+ };
4527
+
4508
4528
  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; }
4509
4529
  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; }
4510
4530
  var SendToApiPane = function SendToApiPane(props) {
@@ -4541,7 +4561,7 @@ var SendToApiForm = function SendToApiForm(_ref) {
4541
4561
  isLoadingTemplates = _useFetchTemplates.isLoading;
4542
4562
  var handleTemplateChange = function handleTemplateChange(setFieldValue, template) {
4543
4563
  setFieldValue("endpoint", template.endpoint);
4544
- setFieldValue("additionalData", template.additionalData);
4564
+ setFieldValue("additionalData", formatAdditionalData(template.additionalData));
4545
4565
  };
4546
4566
  var handleSubmit = function handleSubmit(formValues) {
4547
4567
  var additionalDataModifiedFormValues = ramda.modify("additionalData", rejectEmptyKeyValuePairs, formValues);
@@ -4598,10 +4618,12 @@ var SendToApiForm = function SendToApiForm(_ref) {
4598
4618
  children: /*#__PURE__*/jsxRuntime.jsx(ActionBlock__default["default"], {
4599
4619
  isSubmitting: isSubmitting,
4600
4620
  cancelButtonProps: {
4601
- onClick: onClose
4621
+ onClick: onClose,
4622
+ "data-cy": "api-template-cancel-button"
4602
4623
  },
4603
4624
  submitButtonProps: {
4604
- label: t("neetoMessageTemplate.template.send")
4625
+ label: t("neetoMessageTemplate.template.send"),
4626
+ "data-cy": "api-template-send-button"
4605
4627
  }
4606
4628
  })
4607
4629
  })]