cozy-ui 111.21.0 → 112.0.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 +14 -0
- package/package.json +3 -2
- package/react/FileImageLoader/Readme.md +66 -3
- package/react/FileImageLoader/index.jsx +3 -3
- package/react/FileImageLoader/index.spec.jsx +1 -1
- package/react/hooks/useClientErrors.jsx +140 -0
- package/react/hooks/useClientErrors.spec.jsx +102 -0
- package/react/index.js +0 -1
- package/transpiled/react/FileImageLoader/index.js +3 -3
- package/transpiled/react/hooks/useClientErrors.js +167 -0
- package/transpiled/react/index.js +0 -1
- package/transpiled/react/stylesheet.css +1 -1
- package/react/Viewer/Footer/BottomSheetContent.jsx +0 -29
- package/react/Viewer/Footer/DownloadButton.jsx +0 -67
- package/react/Viewer/Footer/FooterActionButtons.jsx +0 -22
- package/react/Viewer/Footer/FooterActionButtons.spec.jsx +0 -30
- package/react/Viewer/Footer/FooterContent.jsx +0 -99
- package/react/Viewer/Footer/ForwardButton.jsx +0 -95
- package/react/Viewer/Footer/ForwardButton.spec.jsx +0 -87
- package/react/Viewer/Footer/ForwardOrDownloadButton.jsx +0 -24
- package/react/Viewer/Footer/Sharing.jsx +0 -60
- package/react/Viewer/Footer/helpers.js +0 -107
- package/react/Viewer/Footer/helpers.spec.js +0 -77
- package/react/Viewer/NoViewer/DownloadButton.jsx +0 -28
- package/react/Viewer/NoViewer/FileIcon.jsx +0 -46
- package/react/Viewer/NoViewer/NoViewer.jsx +0 -29
- package/react/Viewer/NoViewer/NoViewer.spec.jsx +0 -44
- package/react/Viewer/NoViewer/__snapshots__/NoViewer.spec.jsx.snap +0 -82
- package/react/Viewer/NoViewer/index.jsx +0 -1
- package/react/Viewer/Panel/ActionMenuDesktop.jsx +0 -66
- package/react/Viewer/Panel/ActionMenuMobile.jsx +0 -74
- package/react/Viewer/Panel/ActionMenuWrapper.jsx +0 -104
- package/react/Viewer/Panel/Certifications.jsx +0 -62
- package/react/Viewer/Panel/PanelContent.jsx +0 -49
- package/react/Viewer/Panel/Qualification.jsx +0 -114
- package/react/Viewer/Panel/QualificationListItemContact.jsx +0 -85
- package/react/Viewer/Panel/QualificationListItemDate.jsx +0 -77
- package/react/Viewer/Panel/QualificationListItemInformation.jsx +0 -68
- package/react/Viewer/Panel/QualificationListItemInformation.spec.jsx +0 -73
- package/react/Viewer/Panel/QualificationListItemOther.jsx +0 -61
- package/react/Viewer/Panel/QualificationListItemText.jsx +0 -30
- package/react/Viewer/Panel/getPanelBlocks.jsx +0 -56
- package/react/Viewer/Panel/getPanelBlocks.spec.jsx +0 -79
- package/react/Viewer/Panel/styles.styl +0 -13
- package/react/Viewer/Readme.md +0 -352
- package/react/Viewer/Viewer.jsx +0 -134
- package/react/Viewer/ViewerContainer.jsx +0 -169
- package/react/Viewer/ViewerExposer.js +0 -3
- package/react/Viewer/ViewerInformationsWrapper.jsx +0 -69
- package/react/Viewer/ViewerInformationsWrapper.spec.jsx +0 -63
- package/react/Viewer/ViewerWithCustomPanelAndFooter.jsx +0 -55
- package/react/Viewer/ViewersByFile/AudioViewer.jsx +0 -21
- package/react/Viewer/ViewersByFile/AudioViewer.spec.jsx +0 -39
- package/react/Viewer/ViewersByFile/BlankPaperViewer.jsx +0 -46
- package/react/Viewer/ViewersByFile/ImageViewer.jsx +0 -330
- package/react/Viewer/ViewersByFile/ImageViewer.spec.jsx +0 -70
- package/react/Viewer/ViewersByFile/NoNetworkViewer.jsx +0 -17
- package/react/Viewer/ViewersByFile/OnlyOfficeViewer.jsx +0 -28
- package/react/Viewer/ViewersByFile/PdfJsViewer.jsx +0 -210
- package/react/Viewer/ViewersByFile/PdfJsViewer.spec.jsx +0 -160
- package/react/Viewer/ViewersByFile/PdfMobileViewer.jsx +0 -106
- package/react/Viewer/ViewersByFile/PdfMobileViewer.spec.jsx +0 -76
- package/react/Viewer/ViewersByFile/ShortcutViewer.jsx +0 -38
- package/react/Viewer/ViewersByFile/ShortcutViewer.spec.jsx +0 -32
- package/react/Viewer/ViewersByFile/TextViewer.jsx +0 -126
- package/react/Viewer/ViewersByFile/TextViewer.spec.jsx +0 -118
- package/react/Viewer/ViewersByFile/VideoViewer.jsx +0 -13
- package/react/Viewer/ViewersByFile/VideoViewer.spec.jsx +0 -39
- package/react/Viewer/ViewersByFile/__snapshots__/AudioViewer.spec.jsx.snap +0 -43
- package/react/Viewer/ViewersByFile/__snapshots__/ShortcutViewer.spec.jsx.snap +0 -57
- package/react/Viewer/ViewersByFile/__snapshots__/TextViewer.spec.jsx.snap +0 -100
- package/react/Viewer/ViewersByFile/__snapshots__/VideoViewer.spec.jsx.snap +0 -19
- package/react/Viewer/ViewersByFile/styles.styl +0 -87
- package/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
- package/react/Viewer/components/ExpirationAlert.jsx +0 -86
- package/react/Viewer/components/ExpirationAnnotation.jsx +0 -40
- package/react/Viewer/components/Footer.jsx +0 -13
- package/react/Viewer/components/InformationPanel.jsx +0 -26
- package/react/Viewer/components/Navigation.jsx +0 -39
- package/react/Viewer/components/PdfToolbarButton.jsx +0 -26
- package/react/Viewer/components/PrintButton.jsx +0 -90
- package/react/Viewer/components/Toolbar.jsx +0 -111
- package/react/Viewer/components/ToolbarButtons.jsx +0 -11
- package/react/Viewer/components/ToolbarFilePath.jsx +0 -61
- package/react/Viewer/components/ViewerByFile.jsx +0 -112
- package/react/Viewer/components/ViewerByFile.spec.jsx +0 -100
- package/react/Viewer/components/ViewerControls.jsx +0 -190
- package/react/Viewer/components/ViewerControls.spec.jsx +0 -54
- package/react/Viewer/components/ViewerSpinner.jsx +0 -17
- package/react/Viewer/components/styles.styl +0 -93
- package/react/Viewer/helpers.js +0 -131
- package/react/Viewer/helpers.spec.js +0 -136
- package/react/Viewer/hoc/withFileUrl.jsx +0 -93
- package/react/Viewer/hoc/withViewerLocales.jsx +0 -4
- package/react/Viewer/hooks/useReferencedContactName.jsx +0 -26
- package/react/Viewer/index.jsx +0 -12
- package/react/Viewer/locales/en.json +0 -66
- package/react/Viewer/locales/fr.json +0 -66
- package/react/Viewer/locales/index.js +0 -4
- package/react/Viewer/proptypes.js +0 -12
- package/react/Viewer/providers/ActionMenuProvider.jsx +0 -35
- package/react/Viewer/queries.js +0 -20
- package/react/Viewer/styles.styl +0 -22
- package/react/Viewer/vars.styl +0 -6
- package/transpiled/react/Viewer/Footer/BottomSheetContent.js +0 -28
- package/transpiled/react/Viewer/Footer/DownloadButton.js +0 -91
- package/transpiled/react/Viewer/Footer/FooterActionButtons.js +0 -21
- package/transpiled/react/Viewer/Footer/FooterContent.js +0 -98
- package/transpiled/react/Viewer/Footer/ForwardButton.js +0 -143
- package/transpiled/react/Viewer/Footer/ForwardOrDownloadButton.js +0 -25
- package/transpiled/react/Viewer/Footer/Sharing.js +0 -57
- package/transpiled/react/Viewer/Footer/helpers.js +0 -151
- package/transpiled/react/Viewer/NoViewer/DownloadButton.js +0 -34
- package/transpiled/react/Viewer/NoViewer/FileIcon.js +0 -57
- package/transpiled/react/Viewer/NoViewer/NoViewer.js +0 -49
- package/transpiled/react/Viewer/NoViewer/index.js +0 -1
- package/transpiled/react/Viewer/Panel/ActionMenuDesktop.js +0 -68
- package/transpiled/react/Viewer/Panel/ActionMenuMobile.js +0 -70
- package/transpiled/react/Viewer/Panel/ActionMenuWrapper.js +0 -129
- package/transpiled/react/Viewer/Panel/Certifications.js +0 -56
- package/transpiled/react/Viewer/Panel/PanelContent.js +0 -48
- package/transpiled/react/Viewer/Panel/Qualification.js +0 -119
- package/transpiled/react/Viewer/Panel/QualificationListItemContact.js +0 -96
- package/transpiled/react/Viewer/Panel/QualificationListItemDate.js +0 -64
- package/transpiled/react/Viewer/Panel/QualificationListItemInformation.js +0 -59
- package/transpiled/react/Viewer/Panel/QualificationListItemOther.js +0 -53
- package/transpiled/react/Viewer/Panel/QualificationListItemText.js +0 -29
- package/transpiled/react/Viewer/Panel/getPanelBlocks.js +0 -62
- package/transpiled/react/Viewer/Viewer.js +0 -172
- package/transpiled/react/Viewer/ViewerContainer.js +0 -189
- package/transpiled/react/Viewer/ViewerExposer.js +0 -2
- package/transpiled/react/Viewer/ViewerInformationsWrapper.js +0 -49
- package/transpiled/react/Viewer/ViewerWithCustomPanelAndFooter.js +0 -56
- package/transpiled/react/Viewer/ViewersByFile/AudioViewer.js +0 -41
- package/transpiled/react/Viewer/ViewersByFile/BlankPaperViewer.js +0 -74
- package/transpiled/react/Viewer/ViewersByFile/ImageViewer.js +0 -367
- package/transpiled/react/Viewer/ViewersByFile/NoNetworkViewer.js +0 -38
- package/transpiled/react/Viewer/ViewersByFile/OnlyOfficeViewer.js +0 -29
- package/transpiled/react/Viewer/ViewersByFile/PdfJsViewer.js +0 -254
- package/transpiled/react/Viewer/ViewersByFile/PdfMobileViewer.js +0 -153
- package/transpiled/react/Viewer/ViewersByFile/ShortcutViewer.js +0 -42
- package/transpiled/react/Viewer/ViewersByFile/TextViewer.js +0 -219
- package/transpiled/react/Viewer/ViewersByFile/VideoViewer.js +0 -33
- package/transpiled/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
- package/transpiled/react/Viewer/components/ExpirationAlert.js +0 -100
- package/transpiled/react/Viewer/components/ExpirationAnnotation.js +0 -41
- package/transpiled/react/Viewer/components/Footer.js +0 -29
- package/transpiled/react/Viewer/components/InformationPanel.js +0 -23
- package/transpiled/react/Viewer/components/Navigation.js +0 -47
- package/transpiled/react/Viewer/components/PdfToolbarButton.js +0 -28
- package/transpiled/react/Viewer/components/PrintButton.js +0 -137
- package/transpiled/react/Viewer/components/Toolbar.js +0 -115
- package/transpiled/react/Viewer/components/ToolbarButtons.js +0 -9
- package/transpiled/react/Viewer/components/ToolbarFilePath.js +0 -71
- package/transpiled/react/Viewer/components/ViewerByFile.js +0 -105
- package/transpiled/react/Viewer/components/ViewerControls.js +0 -226
- package/transpiled/react/Viewer/components/ViewerSpinner.js +0 -17
- package/transpiled/react/Viewer/helpers.js +0 -147
- package/transpiled/react/Viewer/hoc/withFileUrl.js +0 -207
- package/transpiled/react/Viewer/hoc/withViewerLocales.js +0 -3
- package/transpiled/react/Viewer/hooks/useReferencedContactName.js +0 -32
- package/transpiled/react/Viewer/index.js +0 -11
- package/transpiled/react/Viewer/locales/index.js +0 -136
- package/transpiled/react/Viewer/proptypes.js +0 -14
- package/transpiled/react/Viewer/providers/ActionMenuProvider.js +0 -34
- package/transpiled/react/Viewer/queries.js +0 -26
- /package/react/{Viewer/providers/EncryptedProvider.jsx → providers/Encrypted/index.jsx} +0 -0
- /package/transpiled/react/{Viewer/providers/EncryptedProvider.js → providers/Encrypted/index.js} +0 -0
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
-
import React, { useState } from 'react';
|
|
3
|
-
var styles = {
|
|
4
|
-
"viewer-imageviewer": "styles__viewer-imageviewer___26k0p",
|
|
5
|
-
"viewer-noviewer": "styles__viewer-noviewer___auG-6",
|
|
6
|
-
"viewer-audioviewer": "styles__viewer-audioviewer___1OQPB",
|
|
7
|
-
"viewer-videoviewer": "styles__viewer-videoviewer___NhFoe",
|
|
8
|
-
"viewer-pdfviewer": "styles__viewer-pdfviewer___1gTP9",
|
|
9
|
-
"viewer-textviewer": "styles__viewer-textviewer___3u5Zw",
|
|
10
|
-
"viewer-canceled": "styles__viewer-canceled___pOA_O",
|
|
11
|
-
"viewer-textviewer-content": "styles__viewer-textviewer-content___PB-c3",
|
|
12
|
-
"viewer-filename": "styles__viewer-filename___3jZCt",
|
|
13
|
-
"viewer-pdfviewer-pdf": "styles__viewer-pdfviewer-pdf___16ID9",
|
|
14
|
-
"viewer-pdfviewer-page": "styles__viewer-pdfviewer-page___2RPuw",
|
|
15
|
-
"viewer-pdfviewer-toolbar": "styles__viewer-pdfviewer-toolbar___3NXOk",
|
|
16
|
-
"viewer-pdfMobile": "styles__viewer-pdfMobile___25FPg",
|
|
17
|
-
"viewer-pdfMobile--image": "styles__viewer-pdfMobile--image___3gpFL"
|
|
18
|
-
};
|
|
19
|
-
import Backdrop from "cozy-ui/transpiled/react/Backdrop";
|
|
20
|
-
import Button from "cozy-ui/transpiled/react/Buttons";
|
|
21
|
-
import Empty from "cozy-ui/transpiled/react/Empty";
|
|
22
|
-
import IntentDialogOpener from "cozy-ui/transpiled/react/IntentDialogOpener";
|
|
23
|
-
import IlluGenericNewPage from "cozy-ui/transpiled/react/Viewer/assets/IlluGenericNewPage.svg";
|
|
24
|
-
import { withViewerLocales } from "cozy-ui/transpiled/react/Viewer/hoc/withViewerLocales";
|
|
25
|
-
|
|
26
|
-
var BlankPaperViewer = function BlankPaperViewer(_ref) {
|
|
27
|
-
var _file$metadata, _file$metadata$qualif;
|
|
28
|
-
|
|
29
|
-
var file = _ref.file,
|
|
30
|
-
t = _ref.t;
|
|
31
|
-
|
|
32
|
-
var _useState = useState(true),
|
|
33
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
34
|
-
isLoading = _useState2[0],
|
|
35
|
-
setIsLoading = _useState2[1];
|
|
36
|
-
|
|
37
|
-
return /*#__PURE__*/React.createElement("div", {
|
|
38
|
-
className: styles['viewer-noviewer']
|
|
39
|
-
}, /*#__PURE__*/React.createElement(Empty, {
|
|
40
|
-
icon: /*#__PURE__*/React.createElement("img", {
|
|
41
|
-
src: IlluGenericNewPage
|
|
42
|
-
}),
|
|
43
|
-
text: t('Viewer.noImage'),
|
|
44
|
-
componentsProps: {
|
|
45
|
-
text: {
|
|
46
|
-
color: 'inherit'
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}, /*#__PURE__*/React.createElement(IntentDialogOpener, {
|
|
50
|
-
action: "OPEN",
|
|
51
|
-
doctype: "io.cozy.files.paper",
|
|
52
|
-
Component: Backdrop,
|
|
53
|
-
invisible: !isLoading,
|
|
54
|
-
isOver: true,
|
|
55
|
-
options: {
|
|
56
|
-
fileId: file._id,
|
|
57
|
-
qualificationLabel: (_file$metadata = file.metadata) === null || _file$metadata === void 0 ? void 0 : (_file$metadata$qualif = _file$metadata.qualification) === null || _file$metadata$qualif === void 0 ? void 0 : _file$metadata$qualif.label
|
|
58
|
-
},
|
|
59
|
-
showCloseButton: false,
|
|
60
|
-
iframeProps: {
|
|
61
|
-
spinnerProps: {
|
|
62
|
-
className: 'u-m-0',
|
|
63
|
-
middle: true,
|
|
64
|
-
color: 'white'
|
|
65
|
-
},
|
|
66
|
-
setIsLoading: setIsLoading
|
|
67
|
-
}
|
|
68
|
-
}, /*#__PURE__*/React.createElement(Button, {
|
|
69
|
-
className: "u-mt-1",
|
|
70
|
-
label: t('Viewer.complete')
|
|
71
|
-
}))));
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
export default withViewerLocales(BlankPaperViewer);
|
|
@@ -1,367 +0,0 @@
|
|
|
1
|
-
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
2
|
-
import _createClass from "@babel/runtime/helpers/createClass";
|
|
3
|
-
import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
|
|
4
|
-
import _inherits from "@babel/runtime/helpers/inherits";
|
|
5
|
-
import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
|
|
6
|
-
import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
|
|
7
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
8
|
-
|
|
9
|
-
function ownKeys(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; }
|
|
10
|
-
|
|
11
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
12
|
-
|
|
13
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
14
|
-
|
|
15
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
16
|
-
|
|
17
|
-
import Hammer from 'hammerjs';
|
|
18
|
-
import React, { Component } from 'react';
|
|
19
|
-
import NoNetworkViewer from "cozy-ui/transpiled/react/Viewer/ViewersByFile/NoNetworkViewer";
|
|
20
|
-
var styles = {
|
|
21
|
-
"viewer-imageviewer": "styles__viewer-imageviewer___26k0p",
|
|
22
|
-
"viewer-noviewer": "styles__viewer-noviewer___auG-6",
|
|
23
|
-
"viewer-audioviewer": "styles__viewer-audioviewer___1OQPB",
|
|
24
|
-
"viewer-videoviewer": "styles__viewer-videoviewer___NhFoe",
|
|
25
|
-
"viewer-pdfviewer": "styles__viewer-pdfviewer___1gTP9",
|
|
26
|
-
"viewer-textviewer": "styles__viewer-textviewer___3u5Zw",
|
|
27
|
-
"viewer-canceled": "styles__viewer-canceled___pOA_O",
|
|
28
|
-
"viewer-textviewer-content": "styles__viewer-textviewer-content___PB-c3",
|
|
29
|
-
"viewer-filename": "styles__viewer-filename___3jZCt",
|
|
30
|
-
"viewer-pdfviewer-pdf": "styles__viewer-pdfviewer-pdf___16ID9",
|
|
31
|
-
"viewer-pdfviewer-page": "styles__viewer-pdfviewer-page___2RPuw",
|
|
32
|
-
"viewer-pdfviewer-toolbar": "styles__viewer-pdfviewer-toolbar___3NXOk",
|
|
33
|
-
"viewer-pdfMobile": "styles__viewer-pdfMobile___25FPg",
|
|
34
|
-
"viewer-pdfMobile--image": "styles__viewer-pdfMobile--image___3gpFL"
|
|
35
|
-
};
|
|
36
|
-
import FileImageLoader from "cozy-ui/transpiled/react/FileImageLoader";
|
|
37
|
-
import ViewerSpinner from "cozy-ui/transpiled/react/Viewer/components/ViewerSpinner";
|
|
38
|
-
var MIN_SCALE = 1;
|
|
39
|
-
var MAX_SCALE = 6;
|
|
40
|
-
var MASS = 10; // If a paning gesture is released while the finger is still moving, the photo will keep paning for a little longer (a if you threw the photo). MASS determines how much the photo will keep paning (the higher the number, the more it will keep going)
|
|
41
|
-
|
|
42
|
-
var FRICTION = 0.9; // When the photo is paning after a pan gesture ended suddenly, FRICTION determines how quickly the movement slows down. 0 would stop it imediately, 1 doesn't slow it down at all.
|
|
43
|
-
|
|
44
|
-
var clamp = function clamp(min, value, max) {
|
|
45
|
-
return Math.max(min, Math.min(max, value));
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
var ImageViewer = /*#__PURE__*/function (_Component) {
|
|
49
|
-
_inherits(ImageViewer, _Component);
|
|
50
|
-
|
|
51
|
-
var _super = _createSuper(ImageViewer);
|
|
52
|
-
|
|
53
|
-
function ImageViewer(props) {
|
|
54
|
-
var _this;
|
|
55
|
-
|
|
56
|
-
_classCallCheck(this, ImageViewer);
|
|
57
|
-
|
|
58
|
-
_this = _super.call(this, props);
|
|
59
|
-
|
|
60
|
-
_defineProperty(_assertThisInitialized(_this), "reload", function () {
|
|
61
|
-
_this.setState(function (state) {
|
|
62
|
-
return _objectSpread(_objectSpread({}, state), {}, {
|
|
63
|
-
loading: true,
|
|
64
|
-
canceled: false
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
_defineProperty(_assertThisInitialized(_this), "onImageError", function () {
|
|
70
|
-
_this.setState(function (state) {
|
|
71
|
-
return _objectSpread(_objectSpread({}, state), {}, {
|
|
72
|
-
loading: false,
|
|
73
|
-
canceled: true
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
_defineProperty(_assertThisInitialized(_this), "onImageLoad", function () {
|
|
79
|
-
_this.setState(function (state) {
|
|
80
|
-
return _objectSpread(_objectSpread({}, state), {}, {
|
|
81
|
-
loading: false
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
_defineProperty(_assertThisInitialized(_this), "onSwipe", function (e) {
|
|
87
|
-
// when a swipe happens while zoomed into an image, it's most likely a pan gesture and not a swipe
|
|
88
|
-
if (_this.state.scale > 1) return; // a pan event is triggered after the swipe and may trigger a getBoundingClientRect error
|
|
89
|
-
|
|
90
|
-
_this.gestures.off('pan');
|
|
91
|
-
|
|
92
|
-
_this.gestures.off('panend');
|
|
93
|
-
|
|
94
|
-
_this.props.onSwipe(e);
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
_this.state = {
|
|
98
|
-
loading: true,
|
|
99
|
-
canceled: false,
|
|
100
|
-
scale: 1,
|
|
101
|
-
offsetX: 0,
|
|
102
|
-
offsetY: 0,
|
|
103
|
-
initialOffset: {
|
|
104
|
-
x: 0,
|
|
105
|
-
y: 0
|
|
106
|
-
},
|
|
107
|
-
initialScale: 0,
|
|
108
|
-
momentum: {
|
|
109
|
-
x: 0,
|
|
110
|
-
y: 0
|
|
111
|
-
}
|
|
112
|
-
};
|
|
113
|
-
return _this;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
_createClass(ImageViewer, [{
|
|
117
|
-
key: "UNSAFE_componentWillReceiveProps",
|
|
118
|
-
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
|
119
|
-
if (nextProps.file && this.props.file && nextProps.file.id !== this.props.file.id) {
|
|
120
|
-
this.tearDownGestures();
|
|
121
|
-
this.setState({
|
|
122
|
-
loading: true,
|
|
123
|
-
canceled: false,
|
|
124
|
-
scale: 1,
|
|
125
|
-
offsetX: 0,
|
|
126
|
-
offsetY: 0
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}, {
|
|
131
|
-
key: "componentDidMount",
|
|
132
|
-
value: function componentDidMount() {
|
|
133
|
-
if (this.props.gestures) this.initGestures();
|
|
134
|
-
}
|
|
135
|
-
}, {
|
|
136
|
-
key: "componentDidUpdate",
|
|
137
|
-
value: function componentDidUpdate(prevProps, prevState) {
|
|
138
|
-
var wasLoading = prevState.loading && !this.state.loading && !this.state.canceled;
|
|
139
|
-
if (!prevProps.gestures) this.initGestures();
|
|
140
|
-
if (wasLoading) this.setupGestures();
|
|
141
|
-
}
|
|
142
|
-
}, {
|
|
143
|
-
key: "componentWillUnmount",
|
|
144
|
-
value: function componentWillUnmount() {
|
|
145
|
-
this.tearDownGestures();
|
|
146
|
-
}
|
|
147
|
-
}, {
|
|
148
|
-
key: "tearDownGestures",
|
|
149
|
-
value: function tearDownGestures() {
|
|
150
|
-
if (this.gestures) {
|
|
151
|
-
this.gestures.off('swipe');
|
|
152
|
-
this.gestures.on('swipe', this.props.onSwipe);
|
|
153
|
-
this.gestures.off('panstart');
|
|
154
|
-
this.gestures.off('pinchstart');
|
|
155
|
-
this.gestures.off('pinchend');
|
|
156
|
-
this.gestures.off('pan');
|
|
157
|
-
this.gestures.off('pinch');
|
|
158
|
-
this.gestures.off('panend');
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}, {
|
|
162
|
-
key: "initGestures",
|
|
163
|
-
value: function initGestures() {
|
|
164
|
-
this.gestures = this.props.gestures;
|
|
165
|
-
this.viewer = this.props.gesturesRef;
|
|
166
|
-
}
|
|
167
|
-
}, {
|
|
168
|
-
key: "setupGestures",
|
|
169
|
-
value: function setupGestures() {
|
|
170
|
-
var _this2 = this;
|
|
171
|
-
|
|
172
|
-
// We replace the swipe handler by ours
|
|
173
|
-
this.gestures.off('swipe');
|
|
174
|
-
this.gestures.on('swipe', this.onSwipe);
|
|
175
|
-
this.gestures.get('pinch').set({
|
|
176
|
-
enable: true
|
|
177
|
-
});
|
|
178
|
-
this.gestures.get('pan').set({
|
|
179
|
-
direction: Hammer.DIRECTION_ALL
|
|
180
|
-
}); // During a gesture, everything is computed with a base value (the state of the image when the gesture starts) and a delta (a translation / zoom, described by the gesture). When a gesture starts, we record the current state of the image.
|
|
181
|
-
|
|
182
|
-
this.gestures.on('panstart', this.prepareForGesture.bind(this));
|
|
183
|
-
this.gestures.on('pinchstart', this.prepareForGesture.bind(this)); // It frequently happens that at the end of a pinch gesture, a pan gesture is detected — because the fingers don't come off the screen at exactly the same time. Reseting the values at the end of the pinch makes sure the values are correct for the (accidental) pan event.
|
|
184
|
-
|
|
185
|
-
this.gestures.on('pinchend', this.prepareForGesture.bind(this)); // during a pan, we add the gestures delta to the initial offset to get the new offset. The new offset is then scaled : if the pan distance was 100px, but the image was scaled 2x, the actual offset should only be 50px. FInally, this value is clamped to make sure the user can't pan further than the edges.
|
|
186
|
-
|
|
187
|
-
this.gestures.on('pan', function (e) {
|
|
188
|
-
_this2.setState(function (state) {
|
|
189
|
-
var maxOffset = _this2.computeMaxOffset();
|
|
190
|
-
|
|
191
|
-
return {
|
|
192
|
-
offsetX: clamp(-maxOffset.x, state.initialOffset.x + e.deltaX / state.scale, maxOffset.x),
|
|
193
|
-
offsetY: clamp(-maxOffset.y, state.initialOffset.y + e.deltaY / state.scale, maxOffset.y)
|
|
194
|
-
};
|
|
195
|
-
});
|
|
196
|
-
}); // pinching / zooming / scaling is a bit more complicated, because the gesture's center has to be taken into account
|
|
197
|
-
|
|
198
|
-
this.gestures.on('pinch', function (e) {
|
|
199
|
-
if (e.isFinal) return; // hard to reproduce, but the final event seems to be causing problems and since it's just replaying the previous event, it can safely be discared
|
|
200
|
-
|
|
201
|
-
_this2.setState(function (state) {
|
|
202
|
-
// first we compute the scale factor: this is the number by which we will multiply the initial scale (as it was before the gesture started) to get the final scaling value. So if the initial scale is 2, and the scale factor is 1.5, the final scale will be 3.
|
|
203
|
-
// this value is clamped so so it stays within reasonable zoom limits.
|
|
204
|
-
var scaleFactor = clamp(MIN_SCALE / state.initialScale, e.scale, MAX_SCALE / state.initialScale); // When the user is zooming in or out, we want that the origin point of the gesture to stay in exactly the same place. The scaling origin is in the center of the viewer.
|
|
205
|
-
// If the gesture's origin is the same as the scaling origin, this works "out of the box" — you can imagine the pixels on all sides being "pushed" towards the outside. But if the gesture's origin is not in the center, we need to offset the whole image to produce the illusion that the scaling center is there.
|
|
206
|
-
// compute the center of the viewer
|
|
207
|
-
|
|
208
|
-
var wrapperBoundaries = _this2.viewer.getBoundingClientRect();
|
|
209
|
-
|
|
210
|
-
var viewerCenter = {
|
|
211
|
-
x: (wrapperBoundaries.right - wrapperBoundaries.left) / 2,
|
|
212
|
-
y: (wrapperBoundaries.bottom - wrapperBoundaries.top) / 2
|
|
213
|
-
}; // Compute the delta between the viewer's center and the gesture's center. This value is scaled back to the "natural" size — if the delta is 100px but the image is currently scale 2x, the real offset value is only 50px.
|
|
214
|
-
|
|
215
|
-
var offsetBeforeScale = {
|
|
216
|
-
x: (viewerCenter.x - e.center.x) / state.scale,
|
|
217
|
-
y: (viewerCenter.y - e.center.y) / state.scale
|
|
218
|
-
}; // Now we compute what this offset will be once we apply the new scale
|
|
219
|
-
|
|
220
|
-
var offsetAfterScale = {
|
|
221
|
-
x: offsetBeforeScale.x * scaleFactor,
|
|
222
|
-
y: offsetBeforeScale.y * scaleFactor
|
|
223
|
-
}; // finally, we compute the actual offset we want to apply. This is the difference between the offset *after* scaling and the offset *before* scaling. We also add any existing offset to preserve it (otherwise it is reset to the center each time)
|
|
224
|
-
|
|
225
|
-
var finalOffset = {
|
|
226
|
-
x: offsetAfterScale.x - offsetBeforeScale.x + state.initialOffset.x,
|
|
227
|
-
y: offsetAfterScale.y - offsetBeforeScale.y + state.initialOffset.y
|
|
228
|
-
}; // last thing: the offsets are clamped to make sure the offsetting doesn't go further than the edges
|
|
229
|
-
|
|
230
|
-
var maxOffset = _this2.computeMaxOffset();
|
|
231
|
-
|
|
232
|
-
return {
|
|
233
|
-
scale: state.initialScale * scaleFactor,
|
|
234
|
-
offsetX: clamp(-maxOffset.x, finalOffset.x, maxOffset.x),
|
|
235
|
-
offsetY: clamp(-maxOffset.y, finalOffset.y, maxOffset.y)
|
|
236
|
-
};
|
|
237
|
-
});
|
|
238
|
-
});
|
|
239
|
-
this.gestures.on('panend', function (e) {
|
|
240
|
-
// convert the remaining velocity into momentum
|
|
241
|
-
_this2.setState({
|
|
242
|
-
momentum: {
|
|
243
|
-
x: e.velocityX * MASS,
|
|
244
|
-
y: e.velocityY * MASS
|
|
245
|
-
}
|
|
246
|
-
}, _this2.applyMomentum.bind(_this2));
|
|
247
|
-
});
|
|
248
|
-
}
|
|
249
|
-
}, {
|
|
250
|
-
key: "render",
|
|
251
|
-
value: function render() {
|
|
252
|
-
var _this3 = this;
|
|
253
|
-
|
|
254
|
-
if (this.state.canceled) {
|
|
255
|
-
return /*#__PURE__*/React.createElement(NoNetworkViewer, {
|
|
256
|
-
onReload: this.reload
|
|
257
|
-
});
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
var _this$props = this.props,
|
|
261
|
-
file = _this$props.file,
|
|
262
|
-
url = _this$props.url;
|
|
263
|
-
var _this$state = this.state,
|
|
264
|
-
scale = _this$state.scale,
|
|
265
|
-
offsetX = _this$state.offsetX,
|
|
266
|
-
offsetY = _this$state.offsetY,
|
|
267
|
-
loading = _this$state.loading;
|
|
268
|
-
var style = {
|
|
269
|
-
transform: "scale(".concat(scale, ") translate(").concat(offsetX, "px, ").concat(offsetY, "px)")
|
|
270
|
-
};
|
|
271
|
-
return /*#__PURE__*/React.createElement("div", {
|
|
272
|
-
className: styles['viewer-imageviewer']
|
|
273
|
-
}, loading && /*#__PURE__*/React.createElement(ViewerSpinner, null), file && /*#__PURE__*/React.createElement(FileImageLoader, {
|
|
274
|
-
file: file,
|
|
275
|
-
url: url,
|
|
276
|
-
linkType: "large",
|
|
277
|
-
onError: this.onImageError,
|
|
278
|
-
key: file.id,
|
|
279
|
-
render: function render(src) {
|
|
280
|
-
return /*#__PURE__*/React.createElement("img", {
|
|
281
|
-
ref: function ref(photo) {
|
|
282
|
-
return _this3.photo = photo;
|
|
283
|
-
},
|
|
284
|
-
style: style,
|
|
285
|
-
alt: file.name,
|
|
286
|
-
src: src,
|
|
287
|
-
onLoad: _this3.onImageLoad
|
|
288
|
-
});
|
|
289
|
-
}
|
|
290
|
-
}));
|
|
291
|
-
}
|
|
292
|
-
/**
|
|
293
|
-
* Things to do when a gesture starts:
|
|
294
|
-
* - saves the current scale and offset, which will be used as base values for calculations
|
|
295
|
-
* - kill any remaining momentum from previous gestures
|
|
296
|
-
* - hide the actions
|
|
297
|
-
*/
|
|
298
|
-
|
|
299
|
-
}, {
|
|
300
|
-
key: "prepareForGesture",
|
|
301
|
-
value: function prepareForGesture() {
|
|
302
|
-
this.setState(function (state) {
|
|
303
|
-
return {
|
|
304
|
-
initialScale: state.scale,
|
|
305
|
-
initialOffset: {
|
|
306
|
-
x: state.offsetX,
|
|
307
|
-
y: state.offsetY
|
|
308
|
-
},
|
|
309
|
-
momentum: {
|
|
310
|
-
x: 0,
|
|
311
|
-
y: 0
|
|
312
|
-
}
|
|
313
|
-
};
|
|
314
|
-
});
|
|
315
|
-
}
|
|
316
|
-
/**
|
|
317
|
-
* Gradually applies the momentum after a pan end
|
|
318
|
-
*/
|
|
319
|
-
|
|
320
|
-
}, {
|
|
321
|
-
key: "applyMomentum",
|
|
322
|
-
value: function applyMomentum() {
|
|
323
|
-
var _this4 = this;
|
|
324
|
-
|
|
325
|
-
this.setState(function (state) {
|
|
326
|
-
var maxOffset = _this4.computeMaxOffset();
|
|
327
|
-
|
|
328
|
-
return {
|
|
329
|
-
offsetX: clamp(-maxOffset.x, state.offsetX + state.momentum.x, maxOffset.x),
|
|
330
|
-
offsetY: clamp(-maxOffset.y, state.offsetY + state.momentum.y, maxOffset.y),
|
|
331
|
-
momentum: {
|
|
332
|
-
x: state.momentum.x * FRICTION,
|
|
333
|
-
y: state.momentum.y * FRICTION
|
|
334
|
-
}
|
|
335
|
-
};
|
|
336
|
-
}, function () {
|
|
337
|
-
if (Math.abs(_this4.state.momentum.x) > 0.1 || Math.abs(_this4.state.momentum.y) > 0.1) requestAnimationFrame(_this4.applyMomentum.bind(_this4));
|
|
338
|
-
});
|
|
339
|
-
}
|
|
340
|
-
/**
|
|
341
|
-
* Compute the maximum offset that can be applied to the photo on each axis before it goes over the edges
|
|
342
|
-
* @returns {object} A point with an x and y property
|
|
343
|
-
*/
|
|
344
|
-
|
|
345
|
-
}, {
|
|
346
|
-
key: "computeMaxOffset",
|
|
347
|
-
value: function computeMaxOffset() {
|
|
348
|
-
if (this.viewer && this.photo) {
|
|
349
|
-
var wrapperBoundaries = this.viewer.getBoundingClientRect();
|
|
350
|
-
var photoBoundaries = this.photo.getBoundingClientRect();
|
|
351
|
-
return {
|
|
352
|
-
x: Math.max(photoBoundaries.width / 2 - wrapperBoundaries.width / 2, 0) / this.state.scale,
|
|
353
|
-
y: Math.max(photoBoundaries.height / 2 - wrapperBoundaries.height / 2, 0) / this.state.scale
|
|
354
|
-
};
|
|
355
|
-
} else {
|
|
356
|
-
return {
|
|
357
|
-
x: 0,
|
|
358
|
-
y: 0
|
|
359
|
-
};
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
}]);
|
|
363
|
-
|
|
364
|
-
return ImageViewer;
|
|
365
|
-
}(Component);
|
|
366
|
-
|
|
367
|
-
export default ImageViewer;
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
var styles = {
|
|
3
|
-
"viewer-imageviewer": "styles__viewer-imageviewer___26k0p",
|
|
4
|
-
"viewer-noviewer": "styles__viewer-noviewer___auG-6",
|
|
5
|
-
"viewer-audioviewer": "styles__viewer-audioviewer___1OQPB",
|
|
6
|
-
"viewer-videoviewer": "styles__viewer-videoviewer___NhFoe",
|
|
7
|
-
"viewer-pdfviewer": "styles__viewer-pdfviewer___1gTP9",
|
|
8
|
-
"viewer-textviewer": "styles__viewer-textviewer___3u5Zw",
|
|
9
|
-
"viewer-canceled": "styles__viewer-canceled___pOA_O",
|
|
10
|
-
"viewer-textviewer-content": "styles__viewer-textviewer-content___PB-c3",
|
|
11
|
-
"viewer-filename": "styles__viewer-filename___3jZCt",
|
|
12
|
-
"viewer-pdfviewer-pdf": "styles__viewer-pdfviewer-pdf___16ID9",
|
|
13
|
-
"viewer-pdfviewer-page": "styles__viewer-pdfviewer-page___2RPuw",
|
|
14
|
-
"viewer-pdfviewer-toolbar": "styles__viewer-pdfviewer-toolbar___3NXOk",
|
|
15
|
-
"viewer-pdfMobile": "styles__viewer-pdfMobile___25FPg",
|
|
16
|
-
"viewer-pdfMobile--image": "styles__viewer-pdfMobile--image___3gpFL"
|
|
17
|
-
};
|
|
18
|
-
import Icon from "cozy-ui/transpiled/react/Icon";
|
|
19
|
-
import CloudBrokenIcon from "cozy-ui/transpiled/react/Icons/CloudBroken";
|
|
20
|
-
import Button from "cozy-ui/transpiled/react/deprecated/Button";
|
|
21
|
-
import { withViewerLocales } from "cozy-ui/transpiled/react/Viewer/hoc/withViewerLocales";
|
|
22
|
-
|
|
23
|
-
var NoNetworkViewer = function NoNetworkViewer(_ref) {
|
|
24
|
-
var t = _ref.t,
|
|
25
|
-
onReload = _ref.onReload;
|
|
26
|
-
return /*#__PURE__*/React.createElement("div", {
|
|
27
|
-
className: styles['viewer-canceled']
|
|
28
|
-
}, /*#__PURE__*/React.createElement(Icon, {
|
|
29
|
-
icon: CloudBrokenIcon,
|
|
30
|
-
width: 160,
|
|
31
|
-
height: 140
|
|
32
|
-
}), /*#__PURE__*/React.createElement("h2", null, t('Viewer.error.network')), /*#__PURE__*/React.createElement(Button, {
|
|
33
|
-
onClick: onReload,
|
|
34
|
-
label: t('Viewer.retry')
|
|
35
|
-
}));
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
export default withViewerLocales(NoNetworkViewer);
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import PropTypes from 'prop-types';
|
|
2
|
-
import React from 'react';
|
|
3
|
-
import Button from "cozy-ui/transpiled/react/deprecated/Button";
|
|
4
|
-
import { FileDoctype } from "cozy-ui/transpiled/react/proptypes";
|
|
5
|
-
import NoViewer from "cozy-ui/transpiled/react/Viewer/NoViewer";
|
|
6
|
-
import { withViewerLocales } from "cozy-ui/transpiled/react/Viewer/hoc/withViewerLocales";
|
|
7
|
-
|
|
8
|
-
var OnlyOfficeViewer = function OnlyOfficeViewer(_ref) {
|
|
9
|
-
var file = _ref.file,
|
|
10
|
-
onlyOfficeOpener = _ref.onlyOfficeOpener,
|
|
11
|
-
t = _ref.t;
|
|
12
|
-
return /*#__PURE__*/React.createElement(NoViewer, {
|
|
13
|
-
file: file,
|
|
14
|
-
renderFallbackExtraContent: function renderFallbackExtraContent() {
|
|
15
|
-
return /*#__PURE__*/React.createElement(Button, {
|
|
16
|
-
label: t('Viewer.openInOnlyOffice'),
|
|
17
|
-
onClick: function onClick() {
|
|
18
|
-
return onlyOfficeOpener(file);
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
OnlyOfficeViewer.propTypes = {
|
|
26
|
-
file: FileDoctype,
|
|
27
|
-
onlyOfficeOpener: PropTypes.func.isRequired
|
|
28
|
-
};
|
|
29
|
-
export default withViewerLocales(OnlyOfficeViewer);
|