@atlaskit/link-datasource 3.13.16 → 3.13.18

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.
Files changed (69) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/dist/cjs/hooks/useLoadOptions.js +20 -9
  3. package/dist/cjs/ui/confluence-search-modal/modal/index.js +8 -27
  4. package/dist/cjs/ui/issue-like-table/edit-type/icon/index.js +4 -1
  5. package/dist/cjs/ui/issue-like-table/edit-type/index.js +9 -4
  6. package/dist/cjs/ui/issue-like-table/edit-type/status/index.js +7 -1
  7. package/dist/cjs/ui/issue-like-table/edit-type/text/index.js +3 -1
  8. package/dist/cjs/ui/issue-like-table/edit-type/user/index.js +7 -1
  9. package/dist/cjs/ui/issue-like-table/index.js +6 -2
  10. package/dist/cjs/ui/issue-like-table/table-cell-content/index.js +5 -0
  11. package/dist/cjs/ui/issue-like-table/table-cell-content/inline-edit.js +31 -2
  12. package/dist/cjs/ui/issue-like-table/table-cell-content/messages.js +14 -0
  13. package/dist/cjs/ui/issue-like-table/utils.js +21 -1
  14. package/dist/cjs/ui/jira-issues-modal/modal/index.js +1 -18
  15. package/dist/es2019/hooks/useLoadOptions.js +15 -4
  16. package/dist/es2019/ui/confluence-search-modal/modal/index.js +12 -35
  17. package/dist/es2019/ui/issue-like-table/edit-type/icon/index.js +4 -1
  18. package/dist/es2019/ui/issue-like-table/edit-type/index.js +9 -4
  19. package/dist/es2019/ui/issue-like-table/edit-type/status/index.js +5 -1
  20. package/dist/es2019/ui/issue-like-table/edit-type/text/index.js +3 -1
  21. package/dist/es2019/ui/issue-like-table/edit-type/user/index.js +5 -1
  22. package/dist/es2019/ui/issue-like-table/index.js +7 -3
  23. package/dist/es2019/ui/issue-like-table/table-cell-content/index.js +5 -0
  24. package/dist/es2019/ui/issue-like-table/table-cell-content/inline-edit.js +33 -3
  25. package/dist/es2019/ui/issue-like-table/table-cell-content/messages.js +8 -0
  26. package/dist/es2019/ui/issue-like-table/utils.js +18 -1
  27. package/dist/es2019/ui/jira-issues-modal/modal/index.js +4 -25
  28. package/dist/esm/hooks/useLoadOptions.js +21 -10
  29. package/dist/esm/ui/confluence-search-modal/modal/index.js +9 -28
  30. package/dist/esm/ui/issue-like-table/edit-type/icon/index.js +4 -1
  31. package/dist/esm/ui/issue-like-table/edit-type/index.js +9 -4
  32. package/dist/esm/ui/issue-like-table/edit-type/status/index.js +7 -1
  33. package/dist/esm/ui/issue-like-table/edit-type/text/index.js +3 -1
  34. package/dist/esm/ui/issue-like-table/edit-type/user/index.js +7 -1
  35. package/dist/esm/ui/issue-like-table/index.js +7 -3
  36. package/dist/esm/ui/issue-like-table/table-cell-content/index.js +5 -0
  37. package/dist/esm/ui/issue-like-table/table-cell-content/inline-edit.js +32 -3
  38. package/dist/esm/ui/issue-like-table/table-cell-content/messages.js +8 -0
  39. package/dist/esm/ui/issue-like-table/utils.js +19 -0
  40. package/dist/esm/ui/jira-issues-modal/modal/index.js +4 -21
  41. package/dist/types/ui/issue-like-table/edit-type/icon/index.d.ts +1 -0
  42. package/dist/types/ui/issue-like-table/edit-type/index.d.ts +2 -1
  43. package/dist/types/ui/issue-like-table/edit-type/status/index.d.ts +1 -0
  44. package/dist/types/ui/issue-like-table/edit-type/text/index.d.ts +1 -0
  45. package/dist/types/ui/issue-like-table/edit-type/user/index.d.ts +1 -0
  46. package/dist/types/ui/issue-like-table/table-cell-content/index.d.ts +2 -1
  47. package/dist/types/ui/issue-like-table/table-cell-content/inline-edit.d.ts +2 -1
  48. package/dist/types/ui/issue-like-table/table-cell-content/messages.d.ts +7 -0
  49. package/dist/types/ui/issue-like-table/utils.d.ts +20 -0
  50. package/dist/types-ts4.5/ui/issue-like-table/edit-type/icon/index.d.ts +1 -0
  51. package/dist/types-ts4.5/ui/issue-like-table/edit-type/index.d.ts +2 -1
  52. package/dist/types-ts4.5/ui/issue-like-table/edit-type/status/index.d.ts +1 -0
  53. package/dist/types-ts4.5/ui/issue-like-table/edit-type/text/index.d.ts +1 -0
  54. package/dist/types-ts4.5/ui/issue-like-table/edit-type/user/index.d.ts +1 -0
  55. package/dist/types-ts4.5/ui/issue-like-table/table-cell-content/index.d.ts +2 -1
  56. package/dist/types-ts4.5/ui/issue-like-table/table-cell-content/inline-edit.d.ts +2 -1
  57. package/dist/types-ts4.5/ui/issue-like-table/table-cell-content/messages.d.ts +7 -0
  58. package/dist/types-ts4.5/ui/issue-like-table/utils.d.ts +20 -0
  59. package/package.json +3 -6
  60. package/dist/cjs/ui/confluence-search-modal/modal/ModalOld.js +0 -455
  61. package/dist/cjs/ui/jira-issues-modal/modal/ModalOld.js +0 -493
  62. package/dist/es2019/ui/confluence-search-modal/modal/ModalOld.js +0 -430
  63. package/dist/es2019/ui/jira-issues-modal/modal/ModalOld.js +0 -476
  64. package/dist/esm/ui/confluence-search-modal/modal/ModalOld.js +0 -451
  65. package/dist/esm/ui/jira-issues-modal/modal/ModalOld.js +0 -490
  66. package/dist/types/ui/confluence-search-modal/modal/ModalOld.d.ts +0 -3
  67. package/dist/types/ui/jira-issues-modal/modal/ModalOld.d.ts +0 -3
  68. package/dist/types-ts4.5/ui/confluence-search-modal/modal/ModalOld.d.ts +0 -3
  69. package/dist/types-ts4.5/ui/jira-issues-modal/modal/ModalOld.d.ts +0 -3
@@ -1,490 +0,0 @@
1
- import _extends from "@babel/runtime/helpers/extends";
2
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
- import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
- 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; }
5
- 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; }
6
- /* eslint-disable @atlaskit/platform/no-preconditioning */
7
- /**
8
- * @jsxRuntime classic
9
- * @jsx jsx
10
- */
11
- import { Fragment, useCallback, useEffect, useMemo, useRef, useState } from 'react';
12
-
13
- // eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
14
- import { jsx } from '@emotion/react';
15
- import { FormattedMessage } from 'react-intl-next';
16
- import Button from '@atlaskit/button/standard-button';
17
- import { IntlMessagesProvider } from '@atlaskit/intl-messages-provider';
18
- import { ModalBody, ModalFooter, ModalHeader, ModalTitle, ModalTransition } from '@atlaskit/modal-dialog';
19
- import { EVENT_CHANNEL, useDatasourceAnalyticsEvents } from '../../../analytics';
20
- import { DatasourceAction, DatasourceDisplay } from '../../../analytics/types';
21
- import { startUfoExperience } from '../../../analytics/ufoExperiences';
22
- import { useColumnPickerRenderedFailedUfoExperience } from '../../../analytics/ufoExperiences/hooks/useColumnPickerRenderedFailedUfoExperience';
23
- import { useDataRenderedUfoExperience } from '../../../analytics/ufoExperiences/hooks/useDataRenderedUfoExperience';
24
- import { mapSearchMethod } from '../../../analytics/utils';
25
- import { buildDatasourceAdf } from '../../../common/utils/adf';
26
- import { fetchMessagesForLocale } from '../../../common/utils/locale/fetch-messages-for-locale';
27
- import { useDatasourceExperienceId } from '../../../contexts/datasource-experience-id';
28
- import { useUserInteractions } from '../../../contexts/user-interactions';
29
- import { useDatasourceTableState } from '../../../hooks/useDatasourceTableState';
30
- import i18nEN from '../../../i18n/en';
31
- import { useAvailableSites } from '../../../services/useAvailableSites';
32
- import { AccessRequired } from '../../common/error-state/access-required';
33
- import { loadingErrorMessages } from '../../common/error-state/messages';
34
- import { ModalLoadingError } from '../../common/error-state/modal-loading-error';
35
- import { NoInstancesView } from '../../common/error-state/no-instances';
36
- import { NoResults } from '../../common/error-state/no-results';
37
- import { InitialStateView } from '../../common/initial-state-view';
38
- import { initialStateViewMessages } from '../../common/initial-state-view/messages';
39
- import { CancelButton } from '../../common/modal/cancel-button';
40
- import { ContentContainer } from '../../common/modal/content-container';
41
- import { SmartCardPlaceholder, SmartLink } from '../../common/modal/count-view-smart-link';
42
- import { DatasourceModal } from '../../common/modal/datasource-modal';
43
- import { useColumnResize } from '../../common/modal/datasources-table-in-modal-preview/use-column-resize';
44
- import { useColumnWrapping } from '../../common/modal/datasources-table-in-modal-preview/use-column-wrapping';
45
- import { DisplayViewDropDown } from '../../common/modal/display-view-dropdown/display-view-drop-down';
46
- import TableSearchCount from '../../common/modal/search-count';
47
- import { SiteSelector } from '../../common/modal/site-selector';
48
- import { EmptyState, IssueLikeDataTableView } from '../../issue-like-table';
49
- import { getColumnAction } from '../../issue-like-table/utils';
50
- import { availableBasicFilterTypes } from '../basic-filters/ui';
51
- import { isQueryTooComplex } from '../basic-filters/utils/isQueryTooComplex';
52
- import { JiraSearchContainer } from '../jira-search-container';
53
- import { JiraInitialStateSVG } from './jira-issues-initial-state-svg';
54
- import { modalMessages } from './messages';
55
- var getDisplayValue = function getDisplayValue(currentViewMode, itemCount) {
56
- if (currentViewMode === 'table') {
57
- return DatasourceDisplay.DATASOURCE_TABLE;
58
- }
59
- return itemCount === 1 ? DatasourceDisplay.INLINE : DatasourceDisplay.DATASOURCE_INLINE;
60
- };
61
- var jqlSupportDocumentLink = 'https://support.atlassian.com/jira-service-management-cloud/docs/use-advanced-search-with-jira-query-language-jql/';
62
- export var PlainJiraIssuesConfigModalOld = function PlainJiraIssuesConfigModalOld(props) {
63
- var datasourceId = props.datasourceId,
64
- initialColumnCustomSizes = props.columnCustomSizes,
65
- initialWrappedColumnKeys = props.wrappedColumnKeys,
66
- onCancel = props.onCancel,
67
- onInsert = props.onInsert,
68
- _props$viewMode = props.viewMode,
69
- viewMode = _props$viewMode === void 0 ? 'table' : _props$viewMode,
70
- initialParameters = props.parameters,
71
- urlBeingEdited = props.url,
72
- initialVisibleColumnKeys = props.visibleColumnKeys,
73
- _props$disableDisplay = props.disableDisplayDropdown,
74
- disableDisplayDropdown = _props$disableDisplay === void 0 ? false : _props$disableDisplay;
75
- var _useState = useState(viewMode),
76
- _useState2 = _slicedToArray(_useState, 2),
77
- currentViewMode = _useState2[0],
78
- setCurrentViewMode = _useState2[1];
79
- var _useState3 = useState(initialParameters === null || initialParameters === void 0 ? void 0 : initialParameters.cloudId),
80
- _useState4 = _slicedToArray(_useState3, 2),
81
- cloudId = _useState4[0],
82
- setCloudId = _useState4[1];
83
- var _useAvailableSites = useAvailableSites('jira', cloudId),
84
- availableSites = _useAvailableSites.availableSites,
85
- selectedJiraSite = _useAvailableSites.selectedSite;
86
- var _useState5 = useState(initialParameters === null || initialParameters === void 0 ? void 0 : initialParameters.jql),
87
- _useState6 = _slicedToArray(_useState5, 2),
88
- jql = _useState6[0],
89
- setJql = _useState6[1];
90
- var _useState7 = useState(initialParameters === null || initialParameters === void 0 ? void 0 : initialParameters.jql),
91
- _useState8 = _slicedToArray(_useState7, 2),
92
- searchBarJql = _useState8[0],
93
- setSearchBarJql = _useState8[1];
94
- var _useState9 = useState(initialVisibleColumnKeys),
95
- _useState10 = _slicedToArray(_useState9, 2),
96
- visibleColumnKeys = _useState10[0],
97
- setVisibleColumnKeys = _useState10[1];
98
-
99
- // analytics related parameters
100
- var searchCount = useRef(0);
101
- var userInteractions = useUserInteractions();
102
- var initialSearchMethod = !isQueryTooComplex((initialParameters === null || initialParameters === void 0 ? void 0 : initialParameters.jql) || '') ? 'basic' : 'jql';
103
- var _useState11 = useState(initialSearchMethod),
104
- _useState12 = _slicedToArray(_useState11, 2),
105
- currentSearchMethod = _useState12[0],
106
- setCurrentSearchMethod = _useState12[1];
107
- var searchMethodSearchedWith = useRef(null);
108
- var visibleColumnCount = useRef((visibleColumnKeys === null || visibleColumnKeys === void 0 ? void 0 : visibleColumnKeys.length) || 0);
109
- var basicFilterSelectionsSearchedWith = useRef({});
110
- var isSearchedWithComplexQuery = useRef(false);
111
- var parameters = useMemo(function () {
112
- return !!cloudId ? {
113
- cloudId: cloudId,
114
- jql: jql || ''
115
- } : undefined;
116
- }, [cloudId, jql]);
117
- var isParametersSet = !!(jql && cloudId);
118
- var _useColumnResize = useColumnResize(initialColumnCustomSizes),
119
- columnCustomSizes = _useColumnResize.columnCustomSizes,
120
- onColumnResize = _useColumnResize.onColumnResize;
121
- var _useColumnWrapping = useColumnWrapping(initialWrappedColumnKeys),
122
- wrappedColumnKeys = _useColumnWrapping.wrappedColumnKeys,
123
- onWrappedColumnChange = _useColumnWrapping.onWrappedColumnChange;
124
- var _useDatasourceTableSt = useDatasourceTableState({
125
- datasourceId: datasourceId,
126
- parameters: isParametersSet ? parameters : undefined,
127
- fieldKeys: visibleColumnKeys
128
- }),
129
- reset = _useDatasourceTableSt.reset,
130
- status = _useDatasourceTableSt.status,
131
- onNextPage = _useDatasourceTableSt.onNextPage,
132
- responseItems = _useDatasourceTableSt.responseItems,
133
- responseItemIds = _useDatasourceTableSt.responseItemIds,
134
- hasNextPage = _useDatasourceTableSt.hasNextPage,
135
- columns = _useDatasourceTableSt.columns,
136
- defaultVisibleColumnKeys = _useDatasourceTableSt.defaultVisibleColumnKeys,
137
- loadDatasourceDetails = _useDatasourceTableSt.loadDatasourceDetails,
138
- totalCount = _useDatasourceTableSt.totalCount,
139
- _useDatasourceTableSt2 = _useDatasourceTableSt.extensionKey,
140
- extensionKey = _useDatasourceTableSt2 === void 0 ? null : _useDatasourceTableSt2,
141
- destinationObjectTypes = _useDatasourceTableSt.destinationObjectTypes;
142
- var _useDatasourceAnalyti = useDatasourceAnalyticsEvents(),
143
- fireEvent = _useDatasourceAnalyti.fireEvent;
144
- var experienceId = useDatasourceExperienceId();
145
- var analyticsPayload = useMemo(function () {
146
- return {
147
- extensionKey: extensionKey,
148
- destinationObjectTypes: destinationObjectTypes
149
- };
150
- }, [destinationObjectTypes, extensionKey]);
151
- var resolvedWithNoResults = status === 'resolved' && !responseItems.length;
152
- var jqlUrl = selectedJiraSite && jql && "".concat(selectedJiraSite.url, "/issues/?jql=").concat(encodeURI(jql));
153
- var isInsertDisabled = !isParametersSet || status === 'rejected' || status === 'unauthorized' || status === 'loading';
154
- var shouldShowIssueCount = !!totalCount && totalCount !== 1 && currentViewMode === 'table';
155
- var isDataReady = (visibleColumnKeys || []).length > 0;
156
- var hasNoJiraSites = availableSites && availableSites.length === 0;
157
- useEffect(function () {
158
- if (availableSites) {
159
- fireEvent('ui.modal.ready.datasource', {
160
- instancesCount: availableSites.length,
161
- schemasCount: null
162
- });
163
- }
164
- }, [fireEvent, availableSites]);
165
- useEffect(function () {
166
- var shouldStartUfoExperience = status === 'loading';
167
- if (shouldStartUfoExperience) {
168
- startUfoExperience({
169
- name: 'datasource-rendered'
170
- }, experienceId);
171
- }
172
- }, [experienceId, status]);
173
- useDataRenderedUfoExperience({
174
- status: status,
175
- experienceId: experienceId,
176
- itemCount: responseItems.length,
177
- canBeLink: currentViewMode === 'inline',
178
- extensionKey: extensionKey
179
- });
180
- useEffect(function () {
181
- var newVisibleColumnKeys = !initialVisibleColumnKeys || (initialVisibleColumnKeys || []).length === 0 ? defaultVisibleColumnKeys : initialVisibleColumnKeys;
182
- visibleColumnCount.current = newVisibleColumnKeys.length;
183
- setVisibleColumnKeys(newVisibleColumnKeys);
184
- }, [initialVisibleColumnKeys, defaultVisibleColumnKeys]);
185
- useEffect(function () {
186
- if (selectedJiraSite && (!cloudId || cloudId !== selectedJiraSite.cloudId)) {
187
- setCloudId(selectedJiraSite.cloudId);
188
- }
189
- }, [cloudId, selectedJiraSite]);
190
- var fireSingleItemViewedEvent = useCallback(function () {
191
- fireEvent('ui.link.viewed.singleItem', _objectSpread(_objectSpread({}, analyticsPayload), {}, {
192
- searchMethod: mapSearchMethod(searchMethodSearchedWith.current)
193
- }));
194
- }, [analyticsPayload, fireEvent]);
195
- var fireCountViewedEvent = useCallback(function () {
196
- fireEvent('ui.link.viewed.count', _objectSpread(_objectSpread({}, analyticsPayload), {}, {
197
- searchMethod: mapSearchMethod(searchMethodSearchedWith.current),
198
- totalItemCount: totalCount || 0
199
- }));
200
- }, [analyticsPayload, fireEvent, totalCount]);
201
- var fireTableViewedEvent = useCallback(function () {
202
- if (isDataReady) {
203
- fireEvent('ui.table.viewed.datasourceConfigModal', _objectSpread(_objectSpread({}, analyticsPayload), {}, {
204
- totalItemCount: totalCount || 0,
205
- searchMethod: mapSearchMethod(searchMethodSearchedWith.current),
206
- displayedColumnCount: visibleColumnCount.current
207
- }));
208
- }
209
- }, [analyticsPayload, fireEvent, totalCount, isDataReady]);
210
- var fireIssueViewAnalytics = useCallback(function () {
211
- if (!totalCount) {
212
- return;
213
- }
214
- if (totalCount > 1) {
215
- fireTableViewedEvent();
216
- } else if (totalCount === 1) {
217
- fireSingleItemViewedEvent();
218
- }
219
- }, [fireSingleItemViewedEvent, fireTableViewedEvent, totalCount]);
220
- useEffect(function () {
221
- var isResolved = status === 'resolved';
222
- var isIssueViewMode = currentViewMode === 'table';
223
- var isCountViewMode = currentViewMode === 'inline';
224
- if (!isResolved) {
225
- return;
226
- }
227
- if (isIssueViewMode) {
228
- fireIssueViewAnalytics();
229
- } else if (isCountViewMode) {
230
- fireCountViewedEvent();
231
- }
232
- }, [currentViewMode, status, fireIssueViewAnalytics, fireCountViewedEvent]);
233
- useColumnPickerRenderedFailedUfoExperience(status, experienceId);
234
- var onSearch = useCallback(function (newParameters, _ref) {
235
- var searchMethod = _ref.searchMethod,
236
- basicFilterSelections = _ref.basicFilterSelections,
237
- isQueryComplex = _ref.isQueryComplex;
238
- searchCount.current++;
239
- searchMethodSearchedWith.current = searchMethod;
240
- basicFilterSelectionsSearchedWith.current = basicFilterSelections;
241
- isSearchedWithComplexQuery.current = isQueryComplex;
242
- if (jql !== newParameters.jql) {
243
- userInteractions.add(DatasourceAction.QUERY_UPDATED);
244
- }
245
- setJql(newParameters.jql);
246
- reset({
247
- shouldForceRequest: true
248
- });
249
- }, [jql, reset, userInteractions]);
250
- var onSiteSelection = useCallback(function (site) {
251
- userInteractions.add(DatasourceAction.INSTANCE_UPDATED);
252
- setJql('');
253
- setCloudId(site.cloudId);
254
- reset({
255
- shouldForceRequest: true
256
- });
257
- }, [reset, userInteractions]);
258
- var retrieveUrlForSmartCardRender = useCallback(function () {
259
- var _data$key;
260
- var _responseItems = _slicedToArray(responseItems, 1),
261
- data = _responseItems[0];
262
- // agreement with BE that we will use `key` for rendering smartlink
263
- return data === null || data === void 0 || (_data$key = data.key) === null || _data$key === void 0 || (_data$key = _data$key.data) === null || _data$key === void 0 ? void 0 : _data$key.url;
264
- }, [responseItems]);
265
- var onInsertPressed = useCallback(function (e, analyticsEvent) {
266
- var _insertButtonClickedE;
267
- if (!isParametersSet || !jql || !selectedJiraSite) {
268
- return;
269
- }
270
- var upToDateJqlUrl = selectedJiraSite && jql && "".concat(selectedJiraSite.url, "/issues/?jql=").concat(encodeURIComponent(jql));
271
- var filterSelectionCount = availableBasicFilterTypes.reduce(function (current, filter) {
272
- var _basicFilterSelection;
273
- return _objectSpread(_objectSpread({}, current), {}, _defineProperty({}, "".concat(filter, "BasicFilterSelectionCount"), ((_basicFilterSelection = basicFilterSelectionsSearchedWith.current[filter]) === null || _basicFilterSelection === void 0 ? void 0 : _basicFilterSelection.length) || 0));
274
- }, {});
275
- var insertButtonClickedEvent = analyticsEvent.update({
276
- actionSubjectId: 'insert',
277
- attributes: _objectSpread(_objectSpread({}, analyticsPayload), {}, {
278
- totalItemCount: totalCount || 0,
279
- displayedColumnCount: visibleColumnCount.current,
280
- display: getDisplayValue(currentViewMode, totalCount || 0),
281
- searchCount: searchCount.current,
282
- searchMethod: mapSearchMethod(searchMethodSearchedWith.current),
283
- actions: userInteractions.get(),
284
- isQueryComplex: isSearchedWithComplexQuery.current
285
- }, searchMethodSearchedWith.current === 'basic' ? _objectSpread({}, filterSelectionCount) : {}),
286
- eventType: 'ui'
287
- });
288
-
289
- // additional event for tracking in confluence against JIM
290
- var macroInsertedEvent = analyticsEvent.clone();
291
- macroInsertedEvent === null || macroInsertedEvent === void 0 || macroInsertedEvent.update({
292
- eventType: 'track',
293
- action: 'inserted',
294
- actionSubject: 'macro',
295
- actionSubjectId: 'jlol',
296
- attributes: _objectSpread(_objectSpread({}, analyticsPayload), {}, {
297
- totalItemCount: totalCount || 0,
298
- displayedColumnCount: visibleColumnCount.current,
299
- display: getDisplayValue(currentViewMode, totalCount || 0),
300
- searchCount: searchCount.current,
301
- searchMethod: mapSearchMethod(searchMethodSearchedWith.current),
302
- actions: userInteractions.get()
303
- })
304
- });
305
- var consumerEvent = (_insertButtonClickedE = insertButtonClickedEvent.clone()) !== null && _insertButtonClickedE !== void 0 ? _insertButtonClickedE : undefined;
306
- insertButtonClickedEvent.fire(EVENT_CHANNEL);
307
- var firstIssueUrl = retrieveUrlForSmartCardRender();
308
- if (currentViewMode === 'inline') {
309
- macroInsertedEvent === null || macroInsertedEvent === void 0 || macroInsertedEvent.fire(EVENT_CHANNEL);
310
- var url = responseItems.length === 1 ? firstIssueUrl : upToDateJqlUrl;
311
- onInsert({
312
- type: 'inlineCard',
313
- attrs: {
314
- url: url
315
- }
316
- }, consumerEvent);
317
- } else {
318
- onInsert(buildDatasourceAdf({
319
- id: datasourceId,
320
- parameters: {
321
- cloudId: cloudId,
322
- jql: jql
323
- },
324
- views: [{
325
- type: 'table',
326
- properties: {
327
- columns: (visibleColumnKeys || []).map(function (key) {
328
- var width = columnCustomSizes === null || columnCustomSizes === void 0 ? void 0 : columnCustomSizes[key];
329
- var isWrapped = wrappedColumnKeys === null || wrappedColumnKeys === void 0 ? void 0 : wrappedColumnKeys.includes(key);
330
- return _objectSpread(_objectSpread({
331
- key: key
332
- }, width ? {
333
- width: width
334
- } : {}), isWrapped ? {
335
- isWrapped: isWrapped
336
- } : {});
337
- })
338
- }
339
- }]
340
- }, upToDateJqlUrl), consumerEvent);
341
- }
342
- }, [isParametersSet, jql, selectedJiraSite, analyticsPayload, totalCount, currentViewMode, retrieveUrlForSmartCardRender, responseItems.length, onInsert, datasourceId, cloudId, visibleColumnKeys, columnCustomSizes, wrappedColumnKeys, userInteractions]);
343
- var handleViewModeChange = function handleViewModeChange(selectedMode) {
344
- userInteractions.add(DatasourceAction.DISPLAY_VIEW_CHANGED);
345
- setCurrentViewMode(selectedMode);
346
- };
347
- var handleOnNextPage = useCallback(function () {
348
- var onNextPageProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
349
- userInteractions.add(DatasourceAction.NEXT_PAGE_SCROLLED);
350
- onNextPage(onNextPageProps);
351
- }, [onNextPage, userInteractions]);
352
- var handleVisibleColumnKeysChange = useCallback(function () {
353
- var newVisibleColumnKeys = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
354
- var columnAction = getColumnAction(visibleColumnKeys || [], newVisibleColumnKeys);
355
- userInteractions.add(columnAction);
356
- visibleColumnCount.current = newVisibleColumnKeys.length;
357
- setVisibleColumnKeys(newVisibleColumnKeys);
358
- }, [visibleColumnKeys, userInteractions]);
359
- var issueLikeDataTableView = useMemo(function () {
360
- return jsx(ContentContainer, {
361
- withTableBorder: true
362
- }, jsx(IssueLikeDataTableView, {
363
- testId: "jira-datasource-table",
364
- status: status,
365
- columns: columns,
366
- items: responseItems,
367
- itemIds: responseItemIds,
368
- hasNextPage: hasNextPage,
369
- visibleColumnKeys: visibleColumnKeys || defaultVisibleColumnKeys,
370
- onNextPage: handleOnNextPage,
371
- onLoadDatasourceDetails: loadDatasourceDetails,
372
- onVisibleColumnKeysChange: handleVisibleColumnKeysChange,
373
- extensionKey: extensionKey,
374
- columnCustomSizes: columnCustomSizes,
375
- onColumnResize: onColumnResize,
376
- wrappedColumnKeys: wrappedColumnKeys,
377
- onWrappedColumnChange: onWrappedColumnChange
378
- }));
379
- }, [status, columns, responseItems, responseItemIds, hasNextPage, visibleColumnKeys, defaultVisibleColumnKeys, handleOnNextPage, loadDatasourceDetails, handleVisibleColumnKeysChange, extensionKey, columnCustomSizes, onColumnResize, wrappedColumnKeys, onWrappedColumnChange]);
380
- var renderCountModeContent = useCallback(function () {
381
- var selectedJiraSiteUrl = selectedJiraSite === null || selectedJiraSite === void 0 ? void 0 : selectedJiraSite.url;
382
- if (status === 'unauthorized') {
383
- return jsx(AccessRequired, {
384
- url: selectedJiraSiteUrl || urlBeingEdited
385
- });
386
- } else if (status === 'empty' || !jql || !selectedJiraSiteUrl) {
387
- return jsx(SmartCardPlaceholder, {
388
- placeholderText: modalMessages.issuesCountSmartCardPlaceholderText
389
- });
390
- } else {
391
- var url;
392
- if (responseItems.length === 1 && retrieveUrlForSmartCardRender()) {
393
- url = retrieveUrlForSmartCardRender();
394
- } else {
395
- url = "".concat(selectedJiraSiteUrl, "/issues/?jql=").concat(encodeURIComponent(jql));
396
- }
397
- return jsx(SmartLink, {
398
- url: url
399
- });
400
- }
401
- }, [jql, selectedJiraSite === null || selectedJiraSite === void 0 ? void 0 : selectedJiraSite.url, status, urlBeingEdited, responseItems, retrieveUrlForSmartCardRender]);
402
- var renderIssuesModeContent = useCallback(function () {
403
- var selectedJiraSiteUrl = selectedJiraSite === null || selectedJiraSite === void 0 ? void 0 : selectedJiraSite.url;
404
- if (status === 'rejected' && jqlUrl) {
405
- return jsx(ModalLoadingError, {
406
- errorMessage: jqlUrl ? jsx(FormattedMessage, _extends({}, modalMessages.checkConnectionWithSource, {
407
- values: {
408
- a: function a(urlText) {
409
- return jsx("a", {
410
- href: jqlUrl
411
- }, urlText);
412
- }
413
- }
414
- })) : undefined
415
- });
416
- } else if (status === 'unauthorized') {
417
- return jsx(AccessRequired, {
418
- url: selectedJiraSiteUrl || urlBeingEdited
419
- });
420
- } else if (resolvedWithNoResults || status === 'forbidden') {
421
- return jsx(NoResults, null);
422
- } else if (status === 'empty' || !columns.length) {
423
- // persist the empty state when making the initial /data request which contains the columns
424
- return jsx(ContentContainer, {
425
- withTableBorder: !!jql
426
- }, !!jql ? jsx(EmptyState, {
427
- testId: "jira-datasource-modal--empty-state"
428
- }) : jsx(InitialStateView, {
429
- icon: jsx(JiraInitialStateSVG, null),
430
- title: modalMessages.searchJiraTitle,
431
- description: currentSearchMethod === 'jql' ? initialStateViewMessages.searchDescriptionForJQLSearch : initialStateViewMessages.searchDescriptionForBasicSearch,
432
- learnMoreLink: currentSearchMethod === 'jql' ? {
433
- href: jqlSupportDocumentLink,
434
- text: initialStateViewMessages.learnMoreLink
435
- } : undefined
436
- }));
437
- }
438
- return issueLikeDataTableView;
439
- }, [columns.length, currentSearchMethod, issueLikeDataTableView, jql, jqlUrl, resolvedWithNoResults, selectedJiraSite === null || selectedJiraSite === void 0 ? void 0 : selectedJiraSite.url, status, urlBeingEdited]);
440
- var siteSelectorLabel = availableSites && availableSites.length > 1 ? modalMessages.insertIssuesTitleManySites : modalMessages.insertIssuesTitle;
441
- var getCancelButtonAnalyticsPayload = useCallback(function () {
442
- return _objectSpread(_objectSpread({}, analyticsPayload), {}, {
443
- searchCount: searchCount.current,
444
- actions: userInteractions.get()
445
- });
446
- }, [analyticsPayload, userInteractions]);
447
- return jsx(IntlMessagesProvider, {
448
- defaultMessages: i18nEN,
449
- loaderFn: fetchMessagesForLocale
450
- }, jsx(ModalTransition, null, jsx(DatasourceModal, {
451
- testId: "jira-datasource-modal",
452
- onClose: onCancel
453
- }, jsx(ModalHeader, null, jsx(ModalTitle, null, jsx(SiteSelector, {
454
- availableSites: availableSites,
455
- onSiteSelection: onSiteSelection,
456
- selectedSite: selectedJiraSite,
457
- testId: "jira-datasource-modal--site-selector",
458
- label: siteSelectorLabel
459
- })), !hasNoJiraSites && !disableDisplayDropdown && jsx(DisplayViewDropDown, {
460
- onViewModeChange: handleViewModeChange,
461
- viewMode: currentViewMode
462
- })), jsx(ModalBody, null, !hasNoJiraSites ? jsx(Fragment, null, jsx(JiraSearchContainer, {
463
- setSearchBarJql: setSearchBarJql,
464
- searchBarJql: searchBarJql,
465
- isSearching: status === 'loading',
466
- parameters: parameters,
467
- onSearch: onSearch,
468
- initialSearchMethod: initialSearchMethod,
469
- onSearchMethodChange: setCurrentSearchMethod,
470
- site: selectedJiraSite
471
- }), currentViewMode === 'inline' ? renderCountModeContent() : renderIssuesModeContent()) : jsx(NoInstancesView, {
472
- title: loadingErrorMessages.noAccessToJiraSitesTitle,
473
- description: loadingErrorMessages.noAccessToJiraSitesDescription,
474
- testId: "no-jira-instances-content"
475
- })), jsx(ModalFooter, null, shouldShowIssueCount && jsx(TableSearchCount, {
476
- searchCount: totalCount,
477
- url: jqlUrl,
478
- prefixTextType: "issue",
479
- testId: "jira-datasource-modal-total-issues-count"
480
- }), jsx(CancelButton, {
481
- onCancel: onCancel,
482
- getAnalyticsPayload: getCancelButtonAnalyticsPayload,
483
- testId: "jira-datasource-modal--cancel-button"
484
- }), !hasNoJiraSites && jsx(Button, {
485
- appearance: "primary",
486
- onClick: onInsertPressed,
487
- isDisabled: isInsertDisabled,
488
- testId: "jira-datasource-modal--insert-button"
489
- }, jsx(FormattedMessage, modalMessages.insertIssuesButtonText))))));
490
- };
@@ -1,3 +0,0 @@
1
- import { jsx } from '@emotion/react';
2
- import { type ConfluenceSearchConfigModalProps } from '../types';
3
- export declare const PlainConfluenceSearchConfigModal: (props: ConfluenceSearchConfigModalProps) => jsx.JSX.Element;
@@ -1,3 +0,0 @@
1
- import { jsx } from '@emotion/react';
2
- import type { JiraConfigModalProps } from '../types';
3
- export declare const PlainJiraIssuesConfigModalOld: (props: JiraConfigModalProps) => jsx.JSX.Element;
@@ -1,3 +0,0 @@
1
- import { jsx } from '@emotion/react';
2
- import { type ConfluenceSearchConfigModalProps } from '../types';
3
- export declare const PlainConfluenceSearchConfigModal: (props: ConfluenceSearchConfigModalProps) => jsx.JSX.Element;
@@ -1,3 +0,0 @@
1
- import { jsx } from '@emotion/react';
2
- import type { JiraConfigModalProps } from '../types';
3
- export declare const PlainJiraIssuesConfigModalOld: (props: JiraConfigModalProps) => jsx.JSX.Element;