@imposium-hub/components 2.2.27 → 2.2.28
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/cjs/components/assets/AssetsTableTagsPivot.js +1 -1
- package/dist/cjs/components/assets/AssetsTableTagsPivot.js.map +1 -1
- package/dist/cjs/components/publish-wizard/PublishWizard.js +2 -1
- package/dist/cjs/components/publish-wizard/PublishWizard.js.map +1 -1
- package/dist/cjs/components/publish-wizard/publish/EmailWorkflow.js +1 -1
- package/dist/cjs/components/publish-wizard/publish/EmailWorkflow.js.map +1 -1
- package/dist/cjs/components/select-field/SelectField.js +4 -3
- package/dist/cjs/components/select-field/SelectField.js.map +1 -1
- package/dist/cjs/components/tag/Tag.d.ts +2 -0
- package/dist/cjs/components/tag/Tag.js +14 -1
- package/dist/cjs/components/tag/Tag.js.map +1 -1
- package/dist/cjs/components/text-area-field/TextAreaField.js +2 -1
- package/dist/cjs/components/text-area-field/TextAreaField.js.map +1 -1
- package/dist/cjs/components/text-field/TextField.js +2 -1
- package/dist/cjs/components/text-field/TextField.js.map +1 -1
- package/dist/cjs/constants/copy.d.ts +1 -0
- package/dist/cjs/constants/copy.js +6 -1
- package/dist/cjs/constants/copy.js.map +1 -1
- package/dist/cjs/services/Session.js +1 -1
- package/dist/cjs/services/Session.js.map +1 -1
- package/dist/esm/components/assets/AssetsTableTagsPivot.js +1 -1
- package/dist/esm/components/assets/AssetsTableTagsPivot.js.map +1 -1
- package/dist/esm/components/publish-wizard/PublishWizard.js +2 -1
- package/dist/esm/components/publish-wizard/PublishWizard.js.map +1 -1
- package/dist/esm/components/publish-wizard/publish/EmailWorkflow.js +1 -1
- package/dist/esm/components/publish-wizard/publish/EmailWorkflow.js.map +1 -1
- package/dist/esm/components/select-field/SelectField.js +4 -3
- package/dist/esm/components/select-field/SelectField.js.map +1 -1
- package/dist/esm/components/tag/Tag.d.ts +2 -0
- package/dist/esm/components/tag/Tag.js +14 -1
- package/dist/esm/components/tag/Tag.js.map +1 -1
- package/dist/esm/components/text-area-field/TextAreaField.js +2 -1
- package/dist/esm/components/text-area-field/TextAreaField.js.map +1 -1
- package/dist/esm/components/text-field/TextField.js +2 -1
- package/dist/esm/components/text-field/TextField.js.map +1 -1
- package/dist/esm/constants/copy.d.ts +1 -0
- package/dist/esm/constants/copy.js +5 -0
- package/dist/esm/constants/copy.js.map +1 -1
- package/dist/esm/services/Session.js +1 -1
- package/dist/esm/services/Session.js.map +1 -1
- package/package.json +1 -1
- package/src/components/assets/AssetsTableTagsPivot.tsx +4 -0
- package/src/components/publish-wizard/PublishWizard.tsx +4 -1
- package/src/components/publish-wizard/publish/EmailWorkflow.tsx +1 -1
- package/src/components/select-field/SelectField.tsx +4 -3
- package/src/components/tag/Tag.tsx +21 -1
- package/src/components/text-area-field/TextAreaField.tsx +2 -1
- package/src/components/text-field/TextField.tsx +2 -1
- package/src/constants/copy.ts +6 -0
- package/src/services/Session.ts +1 -1
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { ICON_TIMES } from '../../constants/icons';
|
|
3
3
|
import { string2HexCode } from '../../Util';
|
|
4
|
+
import { copying } from '../../constants/copy';
|
|
4
5
|
|
|
5
6
|
interface ITagProps {
|
|
6
7
|
copy: string;
|
|
7
8
|
colorize?: boolean;
|
|
8
9
|
removeHandler?: (...args) => any;
|
|
10
|
+
onNotification?: (e) => void;
|
|
11
|
+
onError?: (e) => void;
|
|
9
12
|
}
|
|
10
13
|
|
|
11
14
|
const Tag: React.FC<ITagProps> = (p: ITagProps) => {
|
|
@@ -13,6 +16,22 @@ const Tag: React.FC<ITagProps> = (p: ITagProps) => {
|
|
|
13
16
|
throw new Error('Prop passed to Tag is not string: ');
|
|
14
17
|
}
|
|
15
18
|
|
|
19
|
+
const copyToClipboard = (e) => {
|
|
20
|
+
const { onNotification, onError } = p;
|
|
21
|
+
navigator.clipboard.writeText(e.target.textContent).then(
|
|
22
|
+
() => {
|
|
23
|
+
if (onNotification) {
|
|
24
|
+
onNotification(`${copying.copied}`);
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
() => {
|
|
28
|
+
if (onError) {
|
|
29
|
+
onError(`${copying.error}`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
};
|
|
34
|
+
|
|
16
35
|
const borderLeftColor: string = p.colorize ? `${string2HexCode(p.copy)}` : '';
|
|
17
36
|
const remove = typeof p.removeHandler === 'function' && (
|
|
18
37
|
<div
|
|
@@ -26,7 +45,8 @@ const Tag: React.FC<ITagProps> = (p: ITagProps) => {
|
|
|
26
45
|
<div
|
|
27
46
|
key={p.copy}
|
|
28
47
|
style={{ borderLeftColor }}
|
|
29
|
-
className='imposium-tag'
|
|
48
|
+
className='imposium-tag'
|
|
49
|
+
onClick={(e) => copyToClipboard(e)}>
|
|
30
50
|
{p.copy}
|
|
31
51
|
{remove}
|
|
32
52
|
</div>
|
|
@@ -3,6 +3,7 @@ import Button from '../button/Button';
|
|
|
3
3
|
import FieldWrapper from '../field-wrapper/FieldWrapper';
|
|
4
4
|
import { IToolTipConfig } from '../Tooltip';
|
|
5
5
|
import { ICON_CLIPBOARD, ICON_EDIT, ICON_CHECK } from '../../constants/icons';
|
|
6
|
+
import { copying } from '../../constants/copy';
|
|
6
7
|
|
|
7
8
|
interface ITextAreaFieldProps {
|
|
8
9
|
buttons?: any;
|
|
@@ -123,7 +124,7 @@ class TextAreaField extends React.PureComponent<ITextAreaFieldProps, ITextAreaFi
|
|
|
123
124
|
<Button
|
|
124
125
|
key='btn-copy'
|
|
125
126
|
style='subtle'
|
|
126
|
-
tooltip=
|
|
127
|
+
tooltip={`${copying.tooltip}`}
|
|
127
128
|
color='primary'
|
|
128
129
|
onClick={this.evtHandlers.copyToClipboard}>
|
|
129
130
|
{ICON_CLIPBOARD}
|
|
@@ -14,6 +14,7 @@ import {
|
|
|
14
14
|
} from '../../constants/icons';
|
|
15
15
|
import ReactTextareaAutocomplete from '@imposium-hub/react-textarea-autocomplete';
|
|
16
16
|
import Spinner from '../spinner/Spinner';
|
|
17
|
+
import { copying } from '../../constants/copy';
|
|
17
18
|
|
|
18
19
|
interface ITextFieldProps {
|
|
19
20
|
buttons?: any;
|
|
@@ -396,7 +397,7 @@ class TextField extends React.PureComponent<ITextFieldProps, ITextFieldState> {
|
|
|
396
397
|
key='btn-copy'
|
|
397
398
|
style='subtle'
|
|
398
399
|
color='primary'
|
|
399
|
-
tooltip=
|
|
400
|
+
tooltip={`${copying.tooltip}`}
|
|
400
401
|
onClick={this.evtHandlers.copyToClipboard}>
|
|
401
402
|
{ICON_CLIPBOARD}
|
|
402
403
|
</Button>
|
package/src/constants/copy.ts
CHANGED
|
@@ -248,3 +248,9 @@ export const BATCHES_COPY = {
|
|
|
248
248
|
export const ERROR: any = {
|
|
249
249
|
download: `Unable to download from host server: [error].`
|
|
250
250
|
};
|
|
251
|
+
|
|
252
|
+
export const copying: any = {
|
|
253
|
+
copied: 'Copied to clipboard!',
|
|
254
|
+
error: 'Error copying to clipboard.',
|
|
255
|
+
tooltip: 'Copy to clipboard!'
|
|
256
|
+
};
|
package/src/services/Session.ts
CHANGED
|
@@ -37,7 +37,7 @@ export default class SessionService {
|
|
|
37
37
|
let accessUrl = baseUrl ? `${baseUrl}/access` : SessionService.determineAccessUrl();
|
|
38
38
|
|
|
39
39
|
if (getTotalRenders) {
|
|
40
|
-
accessUrl += '?include_total_renders=true
|
|
40
|
+
accessUrl += '?include_total_renders=true';
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
axios
|