@bigbinary/neeto-slack-frontend 2.2.3 → 2.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +197 -37
- package/dist/index.cjs.js +54 -41
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.js +46 -33
- package/dist/index.js.map +1 -1
- package/package.json +139 -110
- package/types.d.ts +1 -77
- /package/{src → app/javascript/src}/translations/en.json +0 -0
- /package/{src → app/javascript/src}/translations/index.js +0 -0
package/README.md
CHANGED
|
@@ -1,17 +1,34 @@
|
|
|
1
|
-
|
|
1
|
+
# neeto-slack-nano
|
|
2
|
+
|
|
3
|
+
[Engine and package installation](./docs/engine-and-package-installation.md)
|
|
4
|
+
[Building and releasing](./docs/building-and-releasing.md)
|
|
5
|
+
|
|
6
|
+
## Integrations
|
|
7
|
+
|
|
8
|
+
| Projects | Integrated |
|
|
9
|
+
| ------------ | :----------------: |
|
|
10
|
+
| neetoForm | :white_check_mark: |
|
|
11
|
+
| neetoChat | :white_check_mark: |
|
|
12
|
+
| neetoDesk | :white_check_mark: |
|
|
13
|
+
| neetoInvoice | :white_check_mark: |
|
|
14
|
+
| neetoMonitor | :white_check_mark: |
|
|
15
|
+
| neetoBugtrap | :white_check_mark: |
|
|
16
|
+
| neetoCal | :white_check_mark: |
|
|
17
|
+
|
|
18
|
+
## @bigbinary/neeto-slack-frontend
|
|
2
19
|
|
|
3
20
|

|
|
4
21
|

|
|
5
22
|
|
|
6
23
|
UI for slack integration for all neeto products.
|
|
7
24
|
|
|
8
|
-
|
|
25
|
+
### Installation
|
|
9
26
|
|
|
10
27
|
```bash
|
|
11
28
|
yarn add @bigbinary/neeto-slack-frontend
|
|
12
29
|
```
|
|
13
30
|
|
|
14
|
-
|
|
31
|
+
### Usage
|
|
15
32
|
|
|
16
33
|
Available components:
|
|
17
34
|
|
|
@@ -20,9 +37,11 @@ Available components:
|
|
|
20
37
|
- [Finish](./docs/finish/README.md)
|
|
21
38
|
- [Settings](./docs/settings/README.md)
|
|
22
39
|
|
|
23
|
-
|
|
40
|
+
Hook:
|
|
24
41
|
|
|
25
|
-
|
|
42
|
+
- [useFetchSlackIntegrationsStatus](./docs/useFetchSlackIntegrationsStatus/README.md)
|
|
43
|
+
|
|
44
|
+
### Development
|
|
26
45
|
|
|
27
46
|
Install all the dependencies by executing the following command
|
|
28
47
|
|
|
@@ -30,12 +49,7 @@ Install all the dependencies by executing the following command
|
|
|
30
49
|
yarn install
|
|
31
50
|
```
|
|
32
51
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
Start the development server using the `yarn start` command. Development server
|
|
36
|
-
will run the example app using webpack.
|
|
37
|
-
|
|
38
|
-
### Using host application
|
|
52
|
+
#### Using host application
|
|
39
53
|
|
|
40
54
|
1. Clone this repository.
|
|
41
55
|
2. Run `yarn install` to download the dependencies and setup the development
|
|
@@ -53,34 +67,180 @@ will run the example app using webpack.
|
|
|
53
67
|
host if changes are not applied.
|
|
54
68
|
8. Video explanation on how to use yalc: https://vimeo.com/722958162/9e931b640c
|
|
55
69
|
|
|
56
|
-
|
|
70
|
+
## neetoSlackEngine
|
|
71
|
+
|
|
72
|
+
To manage slack integration on neeto applications.
|
|
73
|
+
|
|
74
|
+
### Installation
|
|
75
|
+
|
|
76
|
+
1. Add this line to your application's Gemfile:
|
|
77
|
+
|
|
78
|
+
```ruby
|
|
79
|
+
gem "neeto-slack-engine", git: 'https://github.com/bigbinary/neeto-slack-engine.git', branch: 'stable'
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
2. And then execute:
|
|
83
|
+
|
|
84
|
+
```shell
|
|
85
|
+
bundle install
|
|
86
|
+
```
|
|
57
87
|
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
88
|
+
3. Install the migrations
|
|
89
|
+
|
|
90
|
+
\*\* Add a migration to add slack_chat_api_key to Organization of host app if
|
|
91
|
+
it doesn't exist already. Then run
|
|
92
|
+
|
|
93
|
+
```ruby
|
|
94
|
+
# frozen_string_literal: true
|
|
63
95
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
96
|
+
class AddSlackChatApiKeyToOrganization < ActiveRecord::Migration[7.0]
|
|
97
|
+
def change
|
|
98
|
+
add_column :organizations, :slack_chat_api_key, :string
|
|
99
|
+
end
|
|
100
|
+
end
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
```shell
|
|
104
|
+
bin/rails neeto_slack_engine:install:migrations
|
|
105
|
+
bin/rails db:migrate
|
|
106
|
+
```
|
|
72
107
|
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
108
|
+
4. Configure model to add below association to the integrable class
|
|
109
|
+
|
|
110
|
+
```ruby
|
|
111
|
+
has_one :slack_team, as: :integrable, class_name: "NeetoSlackEngine::SlackTeam", dependent: :destroy
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
5. Configure the following Environment Variables and secrets with suitable
|
|
115
|
+
values
|
|
77
116
|
|
|
78
|
-
|
|
117
|
+
Under .env
|
|
79
118
|
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
119
|
+
```yaml
|
|
120
|
+
SLACK_CLIENT_ID=#Value from Slack App console at
|
|
121
|
+
https://api.slack.com/apps/APP_ID/general SLACK_CLIENT_SECRET=#Value from
|
|
122
|
+
Slack App console at https://api.slack.com/apps/APP_ID/general
|
|
123
|
+
SLACK_CLIENT_SIGNING_SECRET=#Value from Slack App console at
|
|
124
|
+
https://api.slack.com/apps/APP_ID/general ATTR_ENCRYPTION_KEY=#Random varying
|
|
125
|
+
char. key with min. 32 chars. SLACK_REDIRECT_PATH=#Path controller if
|
|
126
|
+
Callbacks controller of application is to be used instead of Engine's
|
|
127
|
+
SLACK_HOST_URL=#Host url if different than application host url or in
|
|
128
|
+
development for use of Ngrok
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
Under secrets.yml
|
|
132
|
+
|
|
133
|
+
```yaml
|
|
134
|
+
application_name: #Application name
|
|
135
|
+
attr_encrypted:
|
|
136
|
+
encryption_key: <%= ENV['ATTR_ENCRYPTION_KEY'] %>
|
|
137
|
+
slack:
|
|
138
|
+
client_id: "<%= ENV['SLACK_CLIENT_ID'] %>"
|
|
139
|
+
client_secret: <%= ENV['SLACK_CLIENT_SECRET'] %>
|
|
140
|
+
client_signing_secret: <%= ENV['SLACK_CLIENT_SIGNING_SECRET'] %>
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
6. Add this line to your application's `config/routes.rb` file (replace `at` to
|
|
144
|
+
your desired route):
|
|
145
|
+
|
|
146
|
+
```ruby
|
|
147
|
+
mount NeetoSlackEngine::Engine, at: '/integrations-slack'
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
7. Slack Integration supports customizing scopes required for host app on usage
|
|
151
|
+
basis, for adding/removing the scope file with name `neeto_slack_engine.yml`
|
|
152
|
+
can be added under host app `config` directory. In case the file is not
|
|
153
|
+
present the Engine fallbacks to set of default scopes defined under Engine
|
|
154
|
+
config. File scope structure
|
|
155
|
+
```yml
|
|
156
|
+
scopes:
|
|
157
|
+
v1:
|
|
158
|
+
bot:
|
|
159
|
+
...
|
|
160
|
+
user:
|
|
161
|
+
...
|
|
162
|
+
v2:
|
|
163
|
+
bot:
|
|
164
|
+
...
|
|
165
|
+
user:
|
|
166
|
+
...
|
|
167
|
+
```
|
|
168
|
+
Ref. -
|
|
169
|
+
https://github.com/bigbinary/neeto-slack-engine/blob/e229fec17fd1b7e8596ca1ca55bd2926133fb88f/test/dummy/config/neeto_slack_engine.yml
|
|
170
|
+
|
|
171
|
+
### Development
|
|
172
|
+
|
|
173
|
+
1. Add this line to your application's Gemfile (replace the path to the local
|
|
174
|
+
copy of neetoIntegrationsSlack's engine):
|
|
175
|
+
|
|
176
|
+
```ruby
|
|
177
|
+
gem 'neeto-slack-engine', path: '../neeto-slack-nano'
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
2. And then execute:
|
|
181
|
+
|
|
182
|
+
```shell
|
|
183
|
+
bundle install
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
3. Install the migrations
|
|
187
|
+
|
|
188
|
+
\*\* Additional migration to add Slack Chat API key to Organization of host
|
|
189
|
+
app.
|
|
190
|
+
|
|
191
|
+
```ruby
|
|
192
|
+
# frozen_string_literal: true
|
|
193
|
+
|
|
194
|
+
class AddSlackChatApiKeyToOrganization < ActiveRecord::Migration[7.0]
|
|
195
|
+
def change
|
|
196
|
+
add_column :organizations, :slack_chat_api_key, :string
|
|
197
|
+
end
|
|
198
|
+
end
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
```shell
|
|
202
|
+
bin/rails neeto_integrations_slack_engine:install:migrations
|
|
203
|
+
bin/rails db:migrate
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
4. Configure model to add below association to the integrable class
|
|
207
|
+
|
|
208
|
+
```ruby
|
|
209
|
+
has_one :slack_team, as: :integrable, class_name: "NeetoSlackEngine::SlackTeam", dependent: :destroy
|
|
210
|
+
```
|
|
211
|
+
|
|
212
|
+
5. Configure the following Environment Variables and secrets with suitable
|
|
213
|
+
values
|
|
214
|
+
|
|
215
|
+
Under `.env.development` or `.env` in application
|
|
216
|
+
|
|
217
|
+
```yaml
|
|
218
|
+
SLACK_CLIENT_ID=#Value from Slack App console at
|
|
219
|
+
https://api.slack.com/apps/APP_ID/general SLACK_CLIENT_SECRET=#Value from
|
|
220
|
+
Slack App console at https://api.slack.com/apps/APP_ID/general
|
|
221
|
+
SLACK_CLIENT_SIGNING_SECRET=#Value from Slack App console at
|
|
222
|
+
https://api.slack.com/apps/APP_ID/general ATTR_ENCRYPTION_KEY=#Random varying
|
|
223
|
+
char. key with min. 32 chars. SLACK_REDIRECT_PATH=#Path controller if
|
|
224
|
+
Callbacks controller of application is to be used instead of Engine's
|
|
225
|
+
SLACK_HOST_URL=#Host url if different than application host url or in
|
|
226
|
+
development for use of Ngrok INTEGRATIONS_SLACK_ENGINE_DEVELOPMENT=true
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
Under secrets.yml
|
|
230
|
+
|
|
231
|
+
```yaml
|
|
232
|
+
application_name: #Application name
|
|
233
|
+
attr_encrypted:
|
|
234
|
+
encryption_key: <%= ENV['ATTR_ENCRYPTION_KEY'] %>
|
|
235
|
+
slack:
|
|
236
|
+
client_id: "<%= ENV['SLACK_CLIENT_ID'] %>"
|
|
237
|
+
client_secret: <%= ENV['SLACK_CLIENT_SECRET'] %>
|
|
238
|
+
client_signing_secret: <%= ENV['SLACK_CLIENT_SIGNING_SECRET'] %>
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
6. Add this line to your application's `config/routes.rb` file (replace `at` to
|
|
242
|
+
your desired route):
|
|
243
|
+
|
|
244
|
+
```ruby
|
|
245
|
+
mount NeetoSlackEngine::Engine, at: '/integrations-slack'
|
|
246
|
+
```
|
package/dist/index.cjs.js
CHANGED
|
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
4
4
|
|
|
5
5
|
var React = require('react');
|
|
6
6
|
var classNames = require('classnames');
|
|
7
|
-
var
|
|
7
|
+
var neetocist = require('neetocist');
|
|
8
8
|
var reactUtils = require('@bigbinary/neeto-commons-frontend/react-utils');
|
|
9
9
|
var neetoui = require('@bigbinary/neetoui');
|
|
10
10
|
var reactI18next = require('react-i18next');
|
|
@@ -116,7 +116,7 @@ var buildValidationSchema = function buildValidationSchema(customValidationSchem
|
|
|
116
116
|
return yup__namespace.object().shape(_objectSpread$2(_objectSpread$2({}, customValidationSchema), CHANNEL_NAME_VALIDAITON_SCHEMA));
|
|
117
117
|
};
|
|
118
118
|
var toSlackUrl = function toSlackUrl(teamName) {
|
|
119
|
-
return "".concat(teamName === null || teamName === void 0 ? void 0 : teamName.replace(/\s/g, "").toLowerCase(), ".slack.com");
|
|
119
|
+
return "https://".concat(teamName === null || teamName === void 0 ? void 0 : teamName.replace(/\s/g, "").toLowerCase(), ".slack.com");
|
|
120
120
|
};
|
|
121
121
|
var slackChannelRefresh = function slackChannelRefresh(channelRefreshHandler) {
|
|
122
122
|
channelRefreshHandler();
|
|
@@ -156,26 +156,37 @@ var SlackRefreshChannelListButton = reactUtils.withT(function (_ref) {
|
|
|
156
156
|
});
|
|
157
157
|
var SlackRefreshChannelListButton$1 = /*#__PURE__*/React__default["default"].memo(SlackRefreshChannelListButton);
|
|
158
158
|
|
|
159
|
+
var ChannelSelectOption = function ChannelSelectOption(_ref) {
|
|
160
|
+
var label = _ref.label,
|
|
161
|
+
isPrivate = _ref.isPrivate;
|
|
162
|
+
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
163
|
+
className: "flex items-center justify-between"
|
|
164
|
+
}, /*#__PURE__*/React__default["default"].createElement("span", null, label), /*#__PURE__*/React__default["default"].createElement(neetoui.Typography, {
|
|
165
|
+
className: "neeto-ui-text-gray-500 italic",
|
|
166
|
+
style: "body3"
|
|
167
|
+
}, isPrivate ? "private" : ""));
|
|
168
|
+
};
|
|
169
|
+
|
|
159
170
|
function ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
160
171
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
161
172
|
var EditPane = function EditPane(_ref) {
|
|
162
173
|
var _ref$isPaneOpen = _ref.isPaneOpen,
|
|
163
174
|
isPaneOpen = _ref$isPaneOpen === void 0 ? false : _ref$isPaneOpen,
|
|
164
175
|
_ref$onClose = _ref.onClose,
|
|
165
|
-
onClose = _ref$onClose === void 0 ?
|
|
176
|
+
onClose = _ref$onClose === void 0 ? neetocist.noop : _ref$onClose,
|
|
166
177
|
_ref$title = _ref.title,
|
|
167
178
|
title = _ref$title === void 0 ? "" : _ref$title,
|
|
168
179
|
children = _ref.children,
|
|
169
180
|
_ref$initialFormValue = _ref.initialFormValues,
|
|
170
181
|
initialFormValues = _ref$initialFormValue === void 0 ? {} : _ref$initialFormValue,
|
|
171
182
|
_ref$handleSubmit = _ref.handleSubmit,
|
|
172
|
-
handleSubmit = _ref$handleSubmit === void 0 ?
|
|
183
|
+
handleSubmit = _ref$handleSubmit === void 0 ? neetocist.noop : _ref$handleSubmit,
|
|
173
184
|
_ref$isSubmitting = _ref.isSubmitting,
|
|
174
185
|
isSubmitting = _ref$isSubmitting === void 0 ? false : _ref$isSubmitting,
|
|
175
186
|
_ref$validationSchema = _ref.validationSchema,
|
|
176
187
|
validationSchema = _ref$validationSchema === void 0 ? {} : _ref$validationSchema,
|
|
177
188
|
_ref$channelRefreshHa = _ref.channelRefreshHandler,
|
|
178
|
-
channelRefreshHandler = _ref$channelRefreshHa === void 0 ?
|
|
189
|
+
channelRefreshHandler = _ref$channelRefreshHa === void 0 ? neetocist.noop : _ref$channelRefreshHa,
|
|
179
190
|
_ref$paneProps = _ref.paneProps,
|
|
180
191
|
paneProps = _ref$paneProps === void 0 ? {} : _ref$paneProps;
|
|
181
192
|
var _useTranslation = reactI18next.useTranslation(),
|
|
@@ -210,7 +221,18 @@ var EditPane = function EditPane(_ref) {
|
|
|
210
221
|
isSearchable: true,
|
|
211
222
|
className: "w-full",
|
|
212
223
|
name: "selectedChannel",
|
|
213
|
-
options: formikProps.values.channels
|
|
224
|
+
options: formikProps.values.channels.map(function (_ref2) {
|
|
225
|
+
var label = _ref2.label,
|
|
226
|
+
value = _ref2.value,
|
|
227
|
+
isPrivate = _ref2.isPrivate;
|
|
228
|
+
return {
|
|
229
|
+
label: /*#__PURE__*/React__default["default"].createElement(ChannelSelectOption, {
|
|
230
|
+
label: label,
|
|
231
|
+
isPrivate: isPrivate
|
|
232
|
+
}),
|
|
233
|
+
value: value
|
|
234
|
+
};
|
|
235
|
+
}),
|
|
214
236
|
placeholder: t("neetoSlack.slack.placeholder"),
|
|
215
237
|
size: "large"
|
|
216
238
|
}), /*#__PURE__*/React__default["default"].createElement(SlackRefreshChannelListButton$1, {
|
|
@@ -233,7 +255,7 @@ var Settings = reactUtils.withT(function (_ref) {
|
|
|
233
255
|
fields = _ref$fields === void 0 ? [] : _ref$fields,
|
|
234
256
|
className = _ref.className,
|
|
235
257
|
_ref$onEdit = _ref.onEdit,
|
|
236
|
-
onEdit = _ref$onEdit === void 0 ?
|
|
258
|
+
onEdit = _ref$onEdit === void 0 ? neetocist.noop : _ref$onEdit;
|
|
237
259
|
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
238
260
|
className: classNames__default["default"]("neeto-ui-w-full neeto-ui-space-y-6", className)
|
|
239
261
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
@@ -320,7 +342,18 @@ var Configure = reactUtils.withT(function (_ref) {
|
|
|
320
342
|
isSearchable: true,
|
|
321
343
|
className: "w-full",
|
|
322
344
|
name: "selectedChannel",
|
|
323
|
-
options: formikProps.values.channels
|
|
345
|
+
options: formikProps.values.channels.map(function (_ref2) {
|
|
346
|
+
var label = _ref2.label,
|
|
347
|
+
value = _ref2.value,
|
|
348
|
+
isPrivate = _ref2.isPrivate;
|
|
349
|
+
return {
|
|
350
|
+
label: /*#__PURE__*/React__default["default"].createElement(ChannelSelectOption, {
|
|
351
|
+
label: label,
|
|
352
|
+
isPrivate: isPrivate
|
|
353
|
+
}),
|
|
354
|
+
value: value
|
|
355
|
+
};
|
|
356
|
+
}),
|
|
324
357
|
placeholder: t("neetoSlack.slack.placeholder"),
|
|
325
358
|
size: "large"
|
|
326
359
|
}), /*#__PURE__*/React__default["default"].createElement(SlackRefreshChannelListButton$1, {
|
|
@@ -359,27 +392,27 @@ var Connect = reactUtils.withT(function (_ref) {
|
|
|
359
392
|
var _path, _defs;
|
|
360
393
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
361
394
|
const SvgSuccess = props => /*#__PURE__*/React__namespace.createElement("svg", _extends({
|
|
395
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
396
|
+
xmlnsXlink: "http://www.w3.org/1999/xlink",
|
|
362
397
|
width: 72,
|
|
363
398
|
height: 72,
|
|
364
|
-
fill: "none"
|
|
365
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
366
|
-
xmlnsXlink: "http://www.w3.org/1999/xlink"
|
|
399
|
+
fill: "none"
|
|
367
400
|
}, props), _path || (_path = /*#__PURE__*/React__namespace.createElement("path", {
|
|
368
401
|
fill: "url(#success_svg__a)",
|
|
369
402
|
d: "M0 0h72v72H0z"
|
|
370
403
|
})), _defs || (_defs = /*#__PURE__*/React__namespace.createElement("defs", null, /*#__PURE__*/React__namespace.createElement("pattern", {
|
|
371
404
|
id: "success_svg__a",
|
|
372
|
-
patternContentUnits: "objectBoundingBox",
|
|
373
405
|
width: 1,
|
|
374
|
-
height: 1
|
|
406
|
+
height: 1,
|
|
407
|
+
patternContentUnits: "objectBoundingBox"
|
|
375
408
|
}, /*#__PURE__*/React__namespace.createElement("use", {
|
|
376
409
|
xlinkHref: "#success_svg__b",
|
|
377
410
|
transform: "scale(.0029)"
|
|
378
411
|
})), /*#__PURE__*/React__namespace.createElement("image", {
|
|
412
|
+
xlinkHref: "",
|
|
379
413
|
id: "success_svg__b",
|
|
380
414
|
width: 344,
|
|
381
|
-
height: 344
|
|
382
|
-
xlinkHref: ""
|
|
415
|
+
height: 344
|
|
383
416
|
}))));
|
|
384
417
|
|
|
385
418
|
var Finish = reactUtils.withT(function (_ref) {
|
|
@@ -390,9 +423,9 @@ var Finish = reactUtils.withT(function (_ref) {
|
|
|
390
423
|
_ref$fields = _ref.fields,
|
|
391
424
|
fields = _ref$fields === void 0 ? [] : _ref$fields,
|
|
392
425
|
_ref$onSuccess = _ref.onSuccess,
|
|
393
|
-
onSuccess = _ref$onSuccess === void 0 ?
|
|
426
|
+
onSuccess = _ref$onSuccess === void 0 ? neetocist.noop : _ref$onSuccess,
|
|
394
427
|
_ref$onBack = _ref.onBack,
|
|
395
|
-
onBack = _ref$onBack === void 0 ?
|
|
428
|
+
onBack = _ref$onBack === void 0 ? neetocist.noop : _ref$onBack,
|
|
396
429
|
_ref$buttonProps = _ref.buttonProps,
|
|
397
430
|
buttonProps = _ref$buttonProps === void 0 ? {} : _ref$buttonProps,
|
|
398
431
|
_ref$secondaryButtonP = _ref.secondaryButtonProps,
|
|
@@ -408,7 +441,7 @@ var Finish = reactUtils.withT(function (_ref) {
|
|
|
408
441
|
values: {
|
|
409
442
|
teamName: teamName
|
|
410
443
|
}
|
|
411
|
-
})),
|
|
444
|
+
})), neetocist.isNotEmpty(fields) && fields.map(function (field, index) {
|
|
412
445
|
return /*#__PURE__*/React__default["default"].createElement(Field, {
|
|
413
446
|
key: field.name,
|
|
414
447
|
name: field.name,
|
|
@@ -423,7 +456,7 @@ var Finish = reactUtils.withT(function (_ref) {
|
|
|
423
456
|
className: "neeto-ui-my-1",
|
|
424
457
|
label: t("neetoSlack.common.done"),
|
|
425
458
|
onClick: onSuccess
|
|
426
|
-
}, buttonProps)),
|
|
459
|
+
}, buttonProps)), neetocist.isNotEmpty(secondaryButtonProps) && /*#__PURE__*/React__default["default"].createElement(neetoui.Button, _extends$1({
|
|
427
460
|
className: "neeto-ui-my-1 neeto-ui-ml-2",
|
|
428
461
|
label: t("neetoSlack.common.edit"),
|
|
429
462
|
style: "secondary",
|
|
@@ -503,29 +536,9 @@ var useFetchSlackIntegrationsStatus = function useFetchSlackIntegrationsStatus(_
|
|
|
503
536
|
}, options));
|
|
504
537
|
};
|
|
505
538
|
|
|
506
|
-
var e = [],
|
|
507
|
-
t = [];
|
|
508
|
-
function n(n, r) {
|
|
509
|
-
if (n && "undefined" != typeof document) {
|
|
510
|
-
var a,
|
|
511
|
-
s = !0 === r.prepend ? "prepend" : "append",
|
|
512
|
-
d = !0 === r.singleTag,
|
|
513
|
-
i = "string" == typeof r.container ? document.querySelector(r.container) : document.getElementsByTagName("head")[0];
|
|
514
|
-
if (d) {
|
|
515
|
-
var u = e.indexOf(i);
|
|
516
|
-
-1 === u && (u = e.push(i) - 1, t[u] = {}), a = t[u] && t[u][s] ? t[u][s] : t[u][s] = c();
|
|
517
|
-
} else a = c();
|
|
518
|
-
65279 === n.charCodeAt(0) && (n = n.substring(1)), a.styleSheet ? a.styleSheet.cssText += n : a.appendChild(document.createTextNode(n));
|
|
519
|
-
}
|
|
520
|
-
function c() {
|
|
521
|
-
var e = document.createElement("style");
|
|
522
|
-
if (e.setAttribute("type", "text/css"), r.attributes) for (var t = Object.keys(r.attributes), n = 0; n < t.length; n++) e.setAttribute(t[n], r.attributes[t[n]]);
|
|
523
|
-
var a = "prepend" === s ? "afterbegin" : "beforeend";
|
|
524
|
-
return i.insertAdjacentElement(a, e), e;
|
|
525
|
-
}
|
|
526
|
-
}
|
|
539
|
+
var e=[],t=[];function n(n,r){if(n&&"undefined"!=typeof document){var a,s=!0===r.prepend?"prepend":"append",d=!0===r.singleTag,i="string"==typeof r.container?document.querySelector(r.container):document.getElementsByTagName("head")[0];if(d){var u=e.indexOf(i);-1===u&&(u=e.push(i)-1,t[u]={}),a=t[u]&&t[u][s]?t[u][s]:t[u][s]=c();}else a=c();65279===n.charCodeAt(0)&&(n=n.substring(1)),a.styleSheet?a.styleSheet.cssText+=n:a.appendChild(document.createTextNode(n));}function c(){var e=document.createElement("style");if(e.setAttribute("type","text/css"),r.attributes)for(var t=Object.keys(r.attributes),n=0;n<t.length;n++)e.setAttribute(t[n],r.attributes[t[n]]);var a="prepend"===s?"afterbegin":"beforeend";return i.insertAdjacentElement(a,e),e}}
|
|
527
540
|
|
|
528
|
-
var css = "
|
|
541
|
+
var css = "@media (max-height:1000px){.neeto-ui-react-select__menu-list{max-height:calc(40vh - 50px)!important}}.border-t{border-top:1px solid}.border-gray-300{border-color:#d1d5db}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC9qYXZhc2NyaXB0L3NyYy9zdHlsZXNoZWV0cy9iYXNlL19vdmVycmlkZXMuc2NzcyIsImFwcC9qYXZhc2NyaXB0L3NyYy9zdHlsZXNoZWV0cy9tYWluLnNjc3MiLCJhcHAvamF2YXNjcmlwdC9zcmMvc3R5bGVzaGVldHMvYmFzZS9fdXRpbGl0aWVzLnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMkJBQ0Usa0NBQ0ksc0NDQ0osQ0FDRixDQ0pBLFVBQ0Usb0JETUYsQ0NKQSxpQkFDRSxvQkRPRiIsInNvdXJjZXNDb250ZW50IjpbIkBtZWRpYSAobWF4LWhlaWdodDogMTAwMHB4KSB7XG4gIC5uZWV0by11aS1yZWFjdC1zZWxlY3RfX21lbnUtbGlzdCB7XG4gICAgICBtYXgtaGVpZ2h0OiBjYWxjKDQwdmggLSA1MHB4KSAhaW1wb3J0YW50O1xuICB9XG59XG4iLCJAbWVkaWEgKG1heC1oZWlnaHQ6IDEwMDBweCkge1xuICAubmVldG8tdWktcmVhY3Qtc2VsZWN0X19tZW51LWxpc3Qge1xuICAgIG1heC1oZWlnaHQ6IGNhbGMoNDB2aCAtIDUwcHgpICFpbXBvcnRhbnQ7XG4gIH1cbn1cbi5ib3JkZXItdCB7XG4gIGJvcmRlci10b3A6IHNvbGlkIDFweDtcbn1cblxuLmJvcmRlci1ncmF5LTMwMCB7XG4gIGJvcmRlci1jb2xvcjogI2QxZDVkYjtcbn0iLCIuYm9yZGVyLXQge1xuICBib3JkZXItdG9wOiBzb2xpZCAxcHg7XG59XG4uYm9yZGVyLWdyYXktMzAwIHtcbiAgYm9yZGVyLWNvbG9yOiAjZDFkNWRiO1xufVxuIl19 */";
|
|
529
542
|
n(css,{});
|
|
530
543
|
|
|
531
544
|
exports.Configure = Configure;
|