@bigbinary/neeto-slack-frontend 2.2.3 → 2.2.4

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 CHANGED
@@ -1,17 +1,34 @@
1
- @bigbinary/neeto-slack-frontend
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
  ![npm](https://img.shields.io/npm/v/@bigbinary/neeto-slack-frontend?color=greenyellow)
4
21
  ![npm](https://img.shields.io/npm/dw/@bigbinary/neeto-slack-frontend?color=greenyellow)
5
22
 
6
23
  UI for slack integration for all neeto products.
7
24
 
8
- ## Installation
25
+ ### Installation
9
26
 
10
27
  ```bash
11
28
  yarn add @bigbinary/neeto-slack-frontend
12
29
  ```
13
30
 
14
- ## Usage
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
- View the [example app](./example/src/App.jsx) to see usage.
40
+ Hook:
24
41
 
25
- ## Development
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
- ### Using example app
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
- # Building and releasing.
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
- The `@bigbinary/neeto-slack-frontend` package gets published to NPM when we
59
- merge a PR with `patch`, `minor` or `major` label to the `main` branch. The
60
- `patch` label is used for bug fixes, `minor` label is used for new features and
61
- `major` label is used for breaking changes. You can checkout the
62
- `Create and publish releases` workflow in GitHub Actions to get a live update.
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
- In case if you missed to add the label, you can manually publish the package.
65
- For that first you need to create a PR to update the version number in the
66
- `package.json` file and merge it to the `main` branch. After merging the PR, you
67
- need to create a
68
- [new github release](https://github.com/bigbinary/neeto-slack-frontend/releases/new)
69
- from main branch. Whenever a new release is created with a new version number,
70
- the github actions will automatically publish the built package to npm. You can
71
- checkout the `Publish to npm` workflow in GitHub Actions to get a live update.
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
- Please note that before publishing the package, you need to verify the
74
- functionality in some of the neeto web-apps locally using `yalc` package
75
- manager. The usage of yalc is explained in this video:
76
- https://youtu.be/QBiYGP0Rhe0
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
- # Product integrations
117
+ Under .env
79
118
 
80
- | Projects | SlackFrontend |
81
- | ------------ | :----------------: |
82
- | neetoChat | :white_check_mark: |
83
- | neetoDesk | :white_check_mark: |
84
- | neetoForm | :white_check_mark: |
85
- | neetoInvoice | :white_check_mark: |
86
- | neetoBugtrap | :white_check_mark: |
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 neetoCist = require('@bigbinary/neeto-cist');
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();
@@ -162,20 +162,20 @@ var EditPane = function EditPane(_ref) {
162
162
  var _ref$isPaneOpen = _ref.isPaneOpen,
163
163
  isPaneOpen = _ref$isPaneOpen === void 0 ? false : _ref$isPaneOpen,
164
164
  _ref$onClose = _ref.onClose,
165
- onClose = _ref$onClose === void 0 ? neetoCist.noop : _ref$onClose,
165
+ onClose = _ref$onClose === void 0 ? neetocist.noop : _ref$onClose,
166
166
  _ref$title = _ref.title,
167
167
  title = _ref$title === void 0 ? "" : _ref$title,
168
168
  children = _ref.children,
169
169
  _ref$initialFormValue = _ref.initialFormValues,
170
170
  initialFormValues = _ref$initialFormValue === void 0 ? {} : _ref$initialFormValue,
171
171
  _ref$handleSubmit = _ref.handleSubmit,
172
- handleSubmit = _ref$handleSubmit === void 0 ? neetoCist.noop : _ref$handleSubmit,
172
+ handleSubmit = _ref$handleSubmit === void 0 ? neetocist.noop : _ref$handleSubmit,
173
173
  _ref$isSubmitting = _ref.isSubmitting,
174
174
  isSubmitting = _ref$isSubmitting === void 0 ? false : _ref$isSubmitting,
175
175
  _ref$validationSchema = _ref.validationSchema,
176
176
  validationSchema = _ref$validationSchema === void 0 ? {} : _ref$validationSchema,
177
177
  _ref$channelRefreshHa = _ref.channelRefreshHandler,
178
- channelRefreshHandler = _ref$channelRefreshHa === void 0 ? neetoCist.noop : _ref$channelRefreshHa,
178
+ channelRefreshHandler = _ref$channelRefreshHa === void 0 ? neetocist.noop : _ref$channelRefreshHa,
179
179
  _ref$paneProps = _ref.paneProps,
180
180
  paneProps = _ref$paneProps === void 0 ? {} : _ref$paneProps;
181
181
  var _useTranslation = reactI18next.useTranslation(),
@@ -233,7 +233,7 @@ var Settings = reactUtils.withT(function (_ref) {
233
233
  fields = _ref$fields === void 0 ? [] : _ref$fields,
234
234
  className = _ref.className,
235
235
  _ref$onEdit = _ref.onEdit,
236
- onEdit = _ref$onEdit === void 0 ? neetoCist.noop : _ref$onEdit;
236
+ onEdit = _ref$onEdit === void 0 ? neetocist.noop : _ref$onEdit;
237
237
  return /*#__PURE__*/React__default["default"].createElement("div", {
238
238
  className: classNames__default["default"]("neeto-ui-w-full neeto-ui-space-y-6", className)
239
239
  }, /*#__PURE__*/React__default["default"].createElement("div", {
@@ -359,27 +359,27 @@ var Connect = reactUtils.withT(function (_ref) {
359
359
  var _path, _defs;
360
360
  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
361
  const SvgSuccess = props => /*#__PURE__*/React__namespace.createElement("svg", _extends({
362
+ xmlns: "http://www.w3.org/2000/svg",
363
+ xmlnsXlink: "http://www.w3.org/1999/xlink",
362
364
  width: 72,
363
365
  height: 72,
364
- fill: "none",
365
- xmlns: "http://www.w3.org/2000/svg",
366
- xmlnsXlink: "http://www.w3.org/1999/xlink"
366
+ fill: "none"
367
367
  }, props), _path || (_path = /*#__PURE__*/React__namespace.createElement("path", {
368
368
  fill: "url(#success_svg__a)",
369
369
  d: "M0 0h72v72H0z"
370
370
  })), _defs || (_defs = /*#__PURE__*/React__namespace.createElement("defs", null, /*#__PURE__*/React__namespace.createElement("pattern", {
371
371
  id: "success_svg__a",
372
- patternContentUnits: "objectBoundingBox",
373
372
  width: 1,
374
- height: 1
373
+ height: 1,
374
+ patternContentUnits: "objectBoundingBox"
375
375
  }, /*#__PURE__*/React__namespace.createElement("use", {
376
376
  xlinkHref: "#success_svg__b",
377
377
  transform: "scale(.0029)"
378
378
  })), /*#__PURE__*/React__namespace.createElement("image", {
379
+ xlinkHref: "",
379
380
  id: "success_svg__b",
380
381
  width: 344,
381
- height: 344,
382
- xlinkHref: ""
382
+ height: 344
383
383
  }))));
384
384
 
385
385
  var Finish = reactUtils.withT(function (_ref) {
@@ -390,9 +390,9 @@ var Finish = reactUtils.withT(function (_ref) {
390
390
  _ref$fields = _ref.fields,
391
391
  fields = _ref$fields === void 0 ? [] : _ref$fields,
392
392
  _ref$onSuccess = _ref.onSuccess,
393
- onSuccess = _ref$onSuccess === void 0 ? neetoCist.noop : _ref$onSuccess,
393
+ onSuccess = _ref$onSuccess === void 0 ? neetocist.noop : _ref$onSuccess,
394
394
  _ref$onBack = _ref.onBack,
395
- onBack = _ref$onBack === void 0 ? neetoCist.noop : _ref$onBack,
395
+ onBack = _ref$onBack === void 0 ? neetocist.noop : _ref$onBack,
396
396
  _ref$buttonProps = _ref.buttonProps,
397
397
  buttonProps = _ref$buttonProps === void 0 ? {} : _ref$buttonProps,
398
398
  _ref$secondaryButtonP = _ref.secondaryButtonProps,
@@ -408,7 +408,7 @@ var Finish = reactUtils.withT(function (_ref) {
408
408
  values: {
409
409
  teamName: teamName
410
410
  }
411
- })), neetoCist.isNotEmpty(fields) && fields.map(function (field, index) {
411
+ })), neetocist.isNotEmpty(fields) && fields.map(function (field, index) {
412
412
  return /*#__PURE__*/React__default["default"].createElement(Field, {
413
413
  key: field.name,
414
414
  name: field.name,
@@ -423,7 +423,7 @@ var Finish = reactUtils.withT(function (_ref) {
423
423
  className: "neeto-ui-my-1",
424
424
  label: t("neetoSlack.common.done"),
425
425
  onClick: onSuccess
426
- }, buttonProps)), neetoCist.isNotEmpty(secondaryButtonProps) && /*#__PURE__*/React__default["default"].createElement(neetoui.Button, _extends$1({
426
+ }, buttonProps)), neetocist.isNotEmpty(secondaryButtonProps) && /*#__PURE__*/React__default["default"].createElement(neetoui.Button, _extends$1({
427
427
  className: "neeto-ui-my-1 neeto-ui-ml-2",
428
428
  label: t("neetoSlack.common.edit"),
429
429
  style: "secondary",
@@ -503,29 +503,9 @@ var useFetchSlackIntegrationsStatus = function useFetchSlackIntegrationsStatus(_
503
503
  }, options));
504
504
  };
505
505
 
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
- }
506
+ 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
507
 
528
- var css = ".w-screen-imp{width:100vw!important}@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}";
508
+ var css = ".w-screen-imp{width:100vw!important}@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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC9qYXZhc2NyaXB0L3NyYy9zdHlsZXNoZWV0cy9vdmVycmlkZXMvX21vZGVsLnNjc3MiLCJhcHAvamF2YXNjcmlwdC9zcmMvc3R5bGVzaGVldHMvbWFpbi5zY3NzIiwiYXBwL2phdmFzY3JpcHQvc3JjL3N0eWxlc2hlZXRzL292ZXJyaWRlcy9fc2VsZWN0LnNjc3MiLCJhcHAvamF2YXNjcmlwdC9zcmMvc3R5bGVzaGVldHMvX3V0aWxpdGllcy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQ0UscUJDQ0YsQ0NGQSwyQkFDRSxrQ0FDSSxzQ0RLSixDQUNGLENFUkEsVUFDRSxvQkZVRixDRVJBLGlCQUNFLG9CRldGIiwic291cmNlc0NvbnRlbnQiOlsiLnctc2NyZWVuLWltcCB7XG4gIHdpZHRoOiAxMDB2dyAhaW1wb3J0YW50O1xufVxuIiwiLnctc2NyZWVuLWltcCB7XG4gIHdpZHRoOiAxMDB2dyAhaW1wb3J0YW50O1xufVxuXG5AbWVkaWEgKG1heC1oZWlnaHQ6IDEwMDBweCkge1xuICAubmVldG8tdWktcmVhY3Qtc2VsZWN0X19tZW51LWxpc3Qge1xuICAgIG1heC1oZWlnaHQ6IGNhbGMoNDB2aCAtIDUwcHgpICFpbXBvcnRhbnQ7XG4gIH1cbn1cbi5ib3JkZXItdCB7XG4gIGJvcmRlci10b3A6IHNvbGlkIDFweDtcbn1cblxuLmJvcmRlci1ncmF5LTMwMCB7XG4gIGJvcmRlci1jb2xvcjogI2QxZDVkYjtcbn0iLCJAbWVkaWEgKG1heC1oZWlnaHQ6IDEwMDBweCkge1xuICAubmVldG8tdWktcmVhY3Qtc2VsZWN0X19tZW51LWxpc3Qge1xuICAgICAgbWF4LWhlaWdodDogY2FsYyg0MHZoIC0gNTBweCkgIWltcG9ydGFudDtcbiAgfVxufVxuIiwiLmJvcmRlci10IHtcbiAgYm9yZGVyLXRvcDogc29saWQgMXB4O1xufVxuLmJvcmRlci1ncmF5LTMwMCB7XG4gIGJvcmRlci1jb2xvcjogI2QxZDVkYjtcbn1cbiJdfQ== */";
529
509
  n(css,{});
530
510
 
531
511
  exports.Configure = Configure;