@digigov/ui 0.17.1 → 0.18.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/CHANGELOG.md +12 -1
- package/app/CopyToClipboard.d.ts +8 -0
- package/app/CopyToClipboard.js +75 -0
- package/app/index.d.ts +1 -0
- package/app/index.js +13 -0
- package/core/Table/index.d.ts +1 -0
- package/core/Table/index.js +13 -0
- package/es/app/CopyToClipboard.js +48 -0
- package/es/app/index.js +2 -1
- package/es/core/Table/index.js +1 -0
- package/es/locales/el.js +3 -0
- package/es/locales/en.js +3 -0
- package/esm/app/CopyToClipboard.js +48 -0
- package/esm/app/index.js +2 -1
- package/esm/core/Table/index.js +1 -0
- package/esm/index.js +1 -1
- package/esm/locales/el.js +3 -0
- package/esm/locales/en.js +3 -0
- package/locales/el.d.ts +3 -0
- package/locales/el.js +3 -0
- package/locales/en.d.ts +3 -0
- package/locales/en.js +3 -0
- package/package.json +3 -3
package/CHANGELOG.md
CHANGED
|
@@ -1,6 +1,17 @@
|
|
|
1
1
|
# Change Log - @digigov/ui
|
|
2
2
|
|
|
3
|
-
This log was last generated on
|
|
3
|
+
This log was last generated on Tue, 03 May 2022 10:27:10 GMT and should not be manually modified.
|
|
4
|
+
|
|
5
|
+
## 0.18.0
|
|
6
|
+
Tue, 03 May 2022 10:27:10 GMT
|
|
7
|
+
|
|
8
|
+
### Minor changes
|
|
9
|
+
|
|
10
|
+
- Add CopyToClipboard component
|
|
11
|
+
|
|
12
|
+
### Patches
|
|
13
|
+
|
|
14
|
+
- reexport TableContainer
|
|
4
15
|
|
|
5
16
|
## 0.17.1
|
|
6
17
|
Wed, 20 Apr 2022 12:11:46 GMT
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
declare type DivElementAttributes = JSX.IntrinsicElements['div'];
|
|
3
|
+
export interface CopyToClipboardProps extends DivElementAttributes {
|
|
4
|
+
text: string;
|
|
5
|
+
variant?: 'tooltip' | 'banner';
|
|
6
|
+
}
|
|
7
|
+
export declare const CopyToClipboard: React.ForwardRefExoticComponent<Pick<CopyToClipboardProps, "color" | "variant" | "className" | "children" | "key" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "slot" | "spellCheck" | "style" | "tabIndex" | "title" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "text"> & React.RefAttributes<HTMLDivElement>>;
|
|
8
|
+
export default CopyToClipboard;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = exports.CopyToClipboard = void 0;
|
|
11
|
+
|
|
12
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
17
|
+
|
|
18
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
19
|
+
|
|
20
|
+
var _clsx = _interopRequireDefault(require("clsx"));
|
|
21
|
+
|
|
22
|
+
var _CopyToClipboardMessage = _interopRequireDefault(require("@digigov/react-extensions/admin/CopyToClipboardMessage"));
|
|
23
|
+
|
|
24
|
+
var _NormalText = _interopRequireDefault(require("@digigov/ui/typography/NormalText"));
|
|
25
|
+
|
|
26
|
+
var _app = require("@digigov/ui/app");
|
|
27
|
+
|
|
28
|
+
var _excluded = ["text", "variant", "children"];
|
|
29
|
+
|
|
30
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
31
|
+
|
|
32
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
33
|
+
|
|
34
|
+
var CopyToClipboard = /*#__PURE__*/_react["default"].forwardRef(function CopyToClipboard(_ref, ref) {
|
|
35
|
+
var text = _ref.text,
|
|
36
|
+
variant = _ref.variant,
|
|
37
|
+
children = _ref.children,
|
|
38
|
+
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
|
39
|
+
|
|
40
|
+
var _useState = (0, _react.useState)(false),
|
|
41
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
42
|
+
enabled = _useState2[0],
|
|
43
|
+
setEnabled = _useState2[1];
|
|
44
|
+
|
|
45
|
+
var _useTranslation = (0, _app.useTranslation)(),
|
|
46
|
+
t = _useTranslation.t;
|
|
47
|
+
|
|
48
|
+
(0, _react.useEffect)(function () {
|
|
49
|
+
var timeout = setTimeout(function () {
|
|
50
|
+
if (enabled) setEnabled(false);
|
|
51
|
+
}, 3000);
|
|
52
|
+
return function () {
|
|
53
|
+
return clearTimeout(timeout);
|
|
54
|
+
};
|
|
55
|
+
}, [enabled]);
|
|
56
|
+
|
|
57
|
+
function copyToClipboard() {
|
|
58
|
+
navigator.clipboard.writeText(text);
|
|
59
|
+
setEnabled(true);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
|
|
63
|
+
ref: ref
|
|
64
|
+
}, props, {
|
|
65
|
+
onClick: copyToClipboard,
|
|
66
|
+
className: (0, _clsx["default"])(variant === 'tooltip' && 'govgr-copy-to-clipboard--root')
|
|
67
|
+
}), children, enabled && /*#__PURE__*/_react["default"].createElement(_CopyToClipboardMessage["default"], {
|
|
68
|
+
variant: variant,
|
|
69
|
+
enabled: enabled
|
|
70
|
+
}, /*#__PURE__*/_react["default"].createElement(_NormalText["default"], null, t('copy-to-clipboard.message'))));
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
exports.CopyToClipboard = CopyToClipboard;
|
|
74
|
+
var _default = CopyToClipboard;
|
|
75
|
+
exports["default"] = _default;
|
package/app/index.d.ts
CHANGED
package/app/index.js
CHANGED
|
@@ -80,4 +80,17 @@ Object.keys(_I18nText).forEach(function (key) {
|
|
|
80
80
|
return _I18nText[key];
|
|
81
81
|
}
|
|
82
82
|
});
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
var _CopyToClipboard = require("@digigov/ui/app/CopyToClipboard");
|
|
86
|
+
|
|
87
|
+
Object.keys(_CopyToClipboard).forEach(function (key) {
|
|
88
|
+
if (key === "default" || key === "__esModule") return;
|
|
89
|
+
if (key in exports && exports[key] === _CopyToClipboard[key]) return;
|
|
90
|
+
Object.defineProperty(exports, key, {
|
|
91
|
+
enumerable: true,
|
|
92
|
+
get: function get() {
|
|
93
|
+
return _CopyToClipboard[key];
|
|
94
|
+
}
|
|
95
|
+
});
|
|
83
96
|
});
|
package/core/Table/index.d.ts
CHANGED
package/core/Table/index.js
CHANGED
|
@@ -4,6 +4,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
|
|
7
|
+
var _TableContainer = require("@digigov/react-core/TableContainer");
|
|
8
|
+
|
|
9
|
+
Object.keys(_TableContainer).forEach(function (key) {
|
|
10
|
+
if (key === "default" || key === "__esModule") return;
|
|
11
|
+
if (key in exports && exports[key] === _TableContainer[key]) return;
|
|
12
|
+
Object.defineProperty(exports, key, {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function get() {
|
|
15
|
+
return _TableContainer[key];
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
|
|
7
20
|
var _Table = require("@digigov/react-core/Table");
|
|
8
21
|
|
|
9
22
|
Object.keys(_Table).forEach(function (key) {
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
|
4
|
+
var _excluded = ["text", "variant", "children"];
|
|
5
|
+
import React, { useState, useEffect } from 'react';
|
|
6
|
+
import clsx from 'clsx';
|
|
7
|
+
import CopyToClipboardMessage from '@digigov/react-extensions/admin/CopyToClipboardMessage';
|
|
8
|
+
import NormalText from '@digigov/ui/typography/NormalText';
|
|
9
|
+
import { useTranslation } from '@digigov/ui/app';
|
|
10
|
+
export var CopyToClipboard = /*#__PURE__*/React.forwardRef(function CopyToClipboard(_ref, ref) {
|
|
11
|
+
var text = _ref.text,
|
|
12
|
+
variant = _ref.variant,
|
|
13
|
+
children = _ref.children,
|
|
14
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
15
|
+
|
|
16
|
+
var _useState = useState(false),
|
|
17
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
18
|
+
enabled = _useState2[0],
|
|
19
|
+
setEnabled = _useState2[1];
|
|
20
|
+
|
|
21
|
+
var _useTranslation = useTranslation(),
|
|
22
|
+
t = _useTranslation.t;
|
|
23
|
+
|
|
24
|
+
useEffect(function () {
|
|
25
|
+
var timeout = setTimeout(function () {
|
|
26
|
+
if (enabled) setEnabled(false);
|
|
27
|
+
}, 3000);
|
|
28
|
+
return function () {
|
|
29
|
+
return clearTimeout(timeout);
|
|
30
|
+
};
|
|
31
|
+
}, [enabled]);
|
|
32
|
+
|
|
33
|
+
function copyToClipboard() {
|
|
34
|
+
navigator.clipboard.writeText(text);
|
|
35
|
+
setEnabled(true);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
|
39
|
+
ref: ref
|
|
40
|
+
}, props, {
|
|
41
|
+
onClick: copyToClipboard,
|
|
42
|
+
className: clsx(variant === 'tooltip' && 'govgr-copy-to-clipboard--root')
|
|
43
|
+
}), children, enabled && /*#__PURE__*/React.createElement(CopyToClipboardMessage, {
|
|
44
|
+
variant: variant,
|
|
45
|
+
enabled: enabled
|
|
46
|
+
}, /*#__PURE__*/React.createElement(NormalText, null, t('copy-to-clipboard.message'))));
|
|
47
|
+
});
|
|
48
|
+
export default CopyToClipboard;
|
package/es/app/index.js
CHANGED
|
@@ -3,4 +3,5 @@ export * from '@digigov/ui/app/PageTitle';
|
|
|
3
3
|
export * from '@digigov/ui/app/QrCodeScanner';
|
|
4
4
|
export * from '@digigov/ui/app/Header';
|
|
5
5
|
export * from '@digigov/ui/app/i18n';
|
|
6
|
-
export * from '@digigov/ui/app/I18nText';
|
|
6
|
+
export * from '@digigov/ui/app/I18nText';
|
|
7
|
+
export * from '@digigov/ui/app/CopyToClipboard';
|
package/es/core/Table/index.js
CHANGED
package/es/locales/el.js
CHANGED
package/es/locales/en.js
CHANGED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
|
4
|
+
var _excluded = ["text", "variant", "children"];
|
|
5
|
+
import React, { useState, useEffect } from 'react';
|
|
6
|
+
import clsx from 'clsx';
|
|
7
|
+
import CopyToClipboardMessage from '@digigov/react-extensions/admin/CopyToClipboardMessage';
|
|
8
|
+
import NormalText from '@digigov/ui/typography/NormalText';
|
|
9
|
+
import { useTranslation } from '@digigov/ui/app';
|
|
10
|
+
export var CopyToClipboard = /*#__PURE__*/React.forwardRef(function CopyToClipboard(_ref, ref) {
|
|
11
|
+
var text = _ref.text,
|
|
12
|
+
variant = _ref.variant,
|
|
13
|
+
children = _ref.children,
|
|
14
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
|
15
|
+
|
|
16
|
+
var _useState = useState(false),
|
|
17
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
18
|
+
enabled = _useState2[0],
|
|
19
|
+
setEnabled = _useState2[1];
|
|
20
|
+
|
|
21
|
+
var _useTranslation = useTranslation(),
|
|
22
|
+
t = _useTranslation.t;
|
|
23
|
+
|
|
24
|
+
useEffect(function () {
|
|
25
|
+
var timeout = setTimeout(function () {
|
|
26
|
+
if (enabled) setEnabled(false);
|
|
27
|
+
}, 3000);
|
|
28
|
+
return function () {
|
|
29
|
+
return clearTimeout(timeout);
|
|
30
|
+
};
|
|
31
|
+
}, [enabled]);
|
|
32
|
+
|
|
33
|
+
function copyToClipboard() {
|
|
34
|
+
navigator.clipboard.writeText(text);
|
|
35
|
+
setEnabled(true);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
|
39
|
+
ref: ref
|
|
40
|
+
}, props, {
|
|
41
|
+
onClick: copyToClipboard,
|
|
42
|
+
className: clsx(variant === 'tooltip' && 'govgr-copy-to-clipboard--root')
|
|
43
|
+
}), children, enabled && /*#__PURE__*/React.createElement(CopyToClipboardMessage, {
|
|
44
|
+
variant: variant,
|
|
45
|
+
enabled: enabled
|
|
46
|
+
}, /*#__PURE__*/React.createElement(NormalText, null, t('copy-to-clipboard.message'))));
|
|
47
|
+
});
|
|
48
|
+
export default CopyToClipboard;
|
package/esm/app/index.js
CHANGED
|
@@ -3,4 +3,5 @@ export * from '@digigov/ui/app/PageTitle';
|
|
|
3
3
|
export * from '@digigov/ui/app/QrCodeScanner';
|
|
4
4
|
export * from '@digigov/ui/app/Header';
|
|
5
5
|
export * from '@digigov/ui/app/i18n';
|
|
6
|
-
export * from '@digigov/ui/app/I18nText';
|
|
6
|
+
export * from '@digigov/ui/app/I18nText';
|
|
7
|
+
export * from '@digigov/ui/app/CopyToClipboard';
|
package/esm/core/Table/index.js
CHANGED
package/esm/index.js
CHANGED
package/esm/locales/el.js
CHANGED
package/esm/locales/en.js
CHANGED
package/locales/el.d.ts
CHANGED
package/locales/el.js
CHANGED
package/locales/en.d.ts
CHANGED
package/locales/en.js
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@digigov/ui",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.18.0",
|
|
4
4
|
"description": "@digigov reusable components toolkit",
|
|
5
5
|
"module": "./esm/index.js",
|
|
6
6
|
"publishConfig": {
|
|
@@ -18,8 +18,8 @@
|
|
|
18
18
|
"clsx": "1.1.1",
|
|
19
19
|
"react": "16.14.0",
|
|
20
20
|
"react-dom": "16.14.0",
|
|
21
|
-
"@digigov/react-core": "0.
|
|
22
|
-
"@digigov/react-extensions": "0.
|
|
21
|
+
"@digigov/react-core": "0.12.0",
|
|
22
|
+
"@digigov/react-extensions": "0.11.0"
|
|
23
23
|
},
|
|
24
24
|
"gitHead": "c903a46306f77f55ad7fc4d2e274006f39a6c871",
|
|
25
25
|
"private": false,
|