cozy-ui 111.20.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.
Files changed (171) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/package.json +3 -2
  3. package/react/FileImageLoader/Readme.md +66 -3
  4. package/react/FileImageLoader/index.jsx +3 -3
  5. package/react/FileImageLoader/index.spec.jsx +1 -1
  6. package/react/Skeletons/ListItemSkeleton.jsx +4 -3
  7. package/react/Skeletons/Readme.md +12 -3
  8. package/react/hooks/useClientErrors.jsx +140 -0
  9. package/react/hooks/useClientErrors.spec.jsx +102 -0
  10. package/react/index.js +0 -1
  11. package/transpiled/react/FileImageLoader/index.js +3 -3
  12. package/transpiled/react/Skeletons/ListItemSkeleton.js +7 -3
  13. package/transpiled/react/hooks/useClientErrors.js +167 -0
  14. package/transpiled/react/index.js +0 -1
  15. package/transpiled/react/stylesheet.css +1 -1
  16. package/react/Viewer/Footer/BottomSheetContent.jsx +0 -29
  17. package/react/Viewer/Footer/DownloadButton.jsx +0 -67
  18. package/react/Viewer/Footer/FooterActionButtons.jsx +0 -22
  19. package/react/Viewer/Footer/FooterActionButtons.spec.jsx +0 -30
  20. package/react/Viewer/Footer/FooterContent.jsx +0 -99
  21. package/react/Viewer/Footer/ForwardButton.jsx +0 -95
  22. package/react/Viewer/Footer/ForwardButton.spec.jsx +0 -87
  23. package/react/Viewer/Footer/ForwardOrDownloadButton.jsx +0 -24
  24. package/react/Viewer/Footer/Sharing.jsx +0 -60
  25. package/react/Viewer/Footer/helpers.js +0 -107
  26. package/react/Viewer/Footer/helpers.spec.js +0 -77
  27. package/react/Viewer/NoViewer/DownloadButton.jsx +0 -28
  28. package/react/Viewer/NoViewer/FileIcon.jsx +0 -46
  29. package/react/Viewer/NoViewer/NoViewer.jsx +0 -29
  30. package/react/Viewer/NoViewer/NoViewer.spec.jsx +0 -44
  31. package/react/Viewer/NoViewer/__snapshots__/NoViewer.spec.jsx.snap +0 -82
  32. package/react/Viewer/NoViewer/index.jsx +0 -1
  33. package/react/Viewer/Panel/ActionMenuDesktop.jsx +0 -66
  34. package/react/Viewer/Panel/ActionMenuMobile.jsx +0 -74
  35. package/react/Viewer/Panel/ActionMenuWrapper.jsx +0 -104
  36. package/react/Viewer/Panel/Certifications.jsx +0 -62
  37. package/react/Viewer/Panel/PanelContent.jsx +0 -49
  38. package/react/Viewer/Panel/Qualification.jsx +0 -114
  39. package/react/Viewer/Panel/QualificationListItemContact.jsx +0 -85
  40. package/react/Viewer/Panel/QualificationListItemDate.jsx +0 -77
  41. package/react/Viewer/Panel/QualificationListItemInformation.jsx +0 -68
  42. package/react/Viewer/Panel/QualificationListItemInformation.spec.jsx +0 -73
  43. package/react/Viewer/Panel/QualificationListItemOther.jsx +0 -61
  44. package/react/Viewer/Panel/QualificationListItemText.jsx +0 -30
  45. package/react/Viewer/Panel/getPanelBlocks.jsx +0 -56
  46. package/react/Viewer/Panel/getPanelBlocks.spec.jsx +0 -79
  47. package/react/Viewer/Panel/styles.styl +0 -13
  48. package/react/Viewer/Readme.md +0 -352
  49. package/react/Viewer/Viewer.jsx +0 -134
  50. package/react/Viewer/ViewerContainer.jsx +0 -169
  51. package/react/Viewer/ViewerExposer.js +0 -3
  52. package/react/Viewer/ViewerInformationsWrapper.jsx +0 -69
  53. package/react/Viewer/ViewerInformationsWrapper.spec.jsx +0 -63
  54. package/react/Viewer/ViewerWithCustomPanelAndFooter.jsx +0 -55
  55. package/react/Viewer/ViewersByFile/AudioViewer.jsx +0 -21
  56. package/react/Viewer/ViewersByFile/AudioViewer.spec.jsx +0 -39
  57. package/react/Viewer/ViewersByFile/BlankPaperViewer.jsx +0 -46
  58. package/react/Viewer/ViewersByFile/ImageViewer.jsx +0 -330
  59. package/react/Viewer/ViewersByFile/ImageViewer.spec.jsx +0 -70
  60. package/react/Viewer/ViewersByFile/NoNetworkViewer.jsx +0 -17
  61. package/react/Viewer/ViewersByFile/OnlyOfficeViewer.jsx +0 -28
  62. package/react/Viewer/ViewersByFile/PdfJsViewer.jsx +0 -210
  63. package/react/Viewer/ViewersByFile/PdfJsViewer.spec.jsx +0 -160
  64. package/react/Viewer/ViewersByFile/PdfMobileViewer.jsx +0 -106
  65. package/react/Viewer/ViewersByFile/PdfMobileViewer.spec.jsx +0 -76
  66. package/react/Viewer/ViewersByFile/ShortcutViewer.jsx +0 -38
  67. package/react/Viewer/ViewersByFile/ShortcutViewer.spec.jsx +0 -32
  68. package/react/Viewer/ViewersByFile/TextViewer.jsx +0 -126
  69. package/react/Viewer/ViewersByFile/TextViewer.spec.jsx +0 -118
  70. package/react/Viewer/ViewersByFile/VideoViewer.jsx +0 -13
  71. package/react/Viewer/ViewersByFile/VideoViewer.spec.jsx +0 -39
  72. package/react/Viewer/ViewersByFile/__snapshots__/AudioViewer.spec.jsx.snap +0 -43
  73. package/react/Viewer/ViewersByFile/__snapshots__/ShortcutViewer.spec.jsx.snap +0 -57
  74. package/react/Viewer/ViewersByFile/__snapshots__/TextViewer.spec.jsx.snap +0 -100
  75. package/react/Viewer/ViewersByFile/__snapshots__/VideoViewer.spec.jsx.snap +0 -19
  76. package/react/Viewer/ViewersByFile/styles.styl +0 -87
  77. package/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
  78. package/react/Viewer/components/ExpirationAlert.jsx +0 -86
  79. package/react/Viewer/components/ExpirationAnnotation.jsx +0 -40
  80. package/react/Viewer/components/Footer.jsx +0 -13
  81. package/react/Viewer/components/InformationPanel.jsx +0 -26
  82. package/react/Viewer/components/Navigation.jsx +0 -39
  83. package/react/Viewer/components/PdfToolbarButton.jsx +0 -26
  84. package/react/Viewer/components/PrintButton.jsx +0 -90
  85. package/react/Viewer/components/Toolbar.jsx +0 -111
  86. package/react/Viewer/components/ToolbarButtons.jsx +0 -11
  87. package/react/Viewer/components/ToolbarFilePath.jsx +0 -61
  88. package/react/Viewer/components/ViewerByFile.jsx +0 -112
  89. package/react/Viewer/components/ViewerByFile.spec.jsx +0 -100
  90. package/react/Viewer/components/ViewerControls.jsx +0 -190
  91. package/react/Viewer/components/ViewerControls.spec.jsx +0 -54
  92. package/react/Viewer/components/ViewerSpinner.jsx +0 -17
  93. package/react/Viewer/components/styles.styl +0 -93
  94. package/react/Viewer/helpers.js +0 -131
  95. package/react/Viewer/helpers.spec.js +0 -136
  96. package/react/Viewer/hoc/withFileUrl.jsx +0 -93
  97. package/react/Viewer/hoc/withViewerLocales.jsx +0 -4
  98. package/react/Viewer/hooks/useReferencedContactName.jsx +0 -26
  99. package/react/Viewer/index.jsx +0 -12
  100. package/react/Viewer/locales/en.json +0 -66
  101. package/react/Viewer/locales/fr.json +0 -66
  102. package/react/Viewer/locales/index.js +0 -4
  103. package/react/Viewer/proptypes.js +0 -12
  104. package/react/Viewer/providers/ActionMenuProvider.jsx +0 -35
  105. package/react/Viewer/queries.js +0 -20
  106. package/react/Viewer/styles.styl +0 -22
  107. package/react/Viewer/vars.styl +0 -6
  108. package/transpiled/react/Viewer/Footer/BottomSheetContent.js +0 -28
  109. package/transpiled/react/Viewer/Footer/DownloadButton.js +0 -91
  110. package/transpiled/react/Viewer/Footer/FooterActionButtons.js +0 -21
  111. package/transpiled/react/Viewer/Footer/FooterContent.js +0 -98
  112. package/transpiled/react/Viewer/Footer/ForwardButton.js +0 -143
  113. package/transpiled/react/Viewer/Footer/ForwardOrDownloadButton.js +0 -25
  114. package/transpiled/react/Viewer/Footer/Sharing.js +0 -57
  115. package/transpiled/react/Viewer/Footer/helpers.js +0 -151
  116. package/transpiled/react/Viewer/NoViewer/DownloadButton.js +0 -34
  117. package/transpiled/react/Viewer/NoViewer/FileIcon.js +0 -57
  118. package/transpiled/react/Viewer/NoViewer/NoViewer.js +0 -49
  119. package/transpiled/react/Viewer/NoViewer/index.js +0 -1
  120. package/transpiled/react/Viewer/Panel/ActionMenuDesktop.js +0 -68
  121. package/transpiled/react/Viewer/Panel/ActionMenuMobile.js +0 -70
  122. package/transpiled/react/Viewer/Panel/ActionMenuWrapper.js +0 -129
  123. package/transpiled/react/Viewer/Panel/Certifications.js +0 -56
  124. package/transpiled/react/Viewer/Panel/PanelContent.js +0 -48
  125. package/transpiled/react/Viewer/Panel/Qualification.js +0 -119
  126. package/transpiled/react/Viewer/Panel/QualificationListItemContact.js +0 -96
  127. package/transpiled/react/Viewer/Panel/QualificationListItemDate.js +0 -64
  128. package/transpiled/react/Viewer/Panel/QualificationListItemInformation.js +0 -59
  129. package/transpiled/react/Viewer/Panel/QualificationListItemOther.js +0 -53
  130. package/transpiled/react/Viewer/Panel/QualificationListItemText.js +0 -29
  131. package/transpiled/react/Viewer/Panel/getPanelBlocks.js +0 -62
  132. package/transpiled/react/Viewer/Viewer.js +0 -172
  133. package/transpiled/react/Viewer/ViewerContainer.js +0 -189
  134. package/transpiled/react/Viewer/ViewerExposer.js +0 -2
  135. package/transpiled/react/Viewer/ViewerInformationsWrapper.js +0 -49
  136. package/transpiled/react/Viewer/ViewerWithCustomPanelAndFooter.js +0 -56
  137. package/transpiled/react/Viewer/ViewersByFile/AudioViewer.js +0 -41
  138. package/transpiled/react/Viewer/ViewersByFile/BlankPaperViewer.js +0 -74
  139. package/transpiled/react/Viewer/ViewersByFile/ImageViewer.js +0 -367
  140. package/transpiled/react/Viewer/ViewersByFile/NoNetworkViewer.js +0 -38
  141. package/transpiled/react/Viewer/ViewersByFile/OnlyOfficeViewer.js +0 -29
  142. package/transpiled/react/Viewer/ViewersByFile/PdfJsViewer.js +0 -254
  143. package/transpiled/react/Viewer/ViewersByFile/PdfMobileViewer.js +0 -153
  144. package/transpiled/react/Viewer/ViewersByFile/ShortcutViewer.js +0 -42
  145. package/transpiled/react/Viewer/ViewersByFile/TextViewer.js +0 -219
  146. package/transpiled/react/Viewer/ViewersByFile/VideoViewer.js +0 -33
  147. package/transpiled/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
  148. package/transpiled/react/Viewer/components/ExpirationAlert.js +0 -100
  149. package/transpiled/react/Viewer/components/ExpirationAnnotation.js +0 -41
  150. package/transpiled/react/Viewer/components/Footer.js +0 -29
  151. package/transpiled/react/Viewer/components/InformationPanel.js +0 -23
  152. package/transpiled/react/Viewer/components/Navigation.js +0 -47
  153. package/transpiled/react/Viewer/components/PdfToolbarButton.js +0 -28
  154. package/transpiled/react/Viewer/components/PrintButton.js +0 -137
  155. package/transpiled/react/Viewer/components/Toolbar.js +0 -115
  156. package/transpiled/react/Viewer/components/ToolbarButtons.js +0 -9
  157. package/transpiled/react/Viewer/components/ToolbarFilePath.js +0 -71
  158. package/transpiled/react/Viewer/components/ViewerByFile.js +0 -105
  159. package/transpiled/react/Viewer/components/ViewerControls.js +0 -226
  160. package/transpiled/react/Viewer/components/ViewerSpinner.js +0 -17
  161. package/transpiled/react/Viewer/helpers.js +0 -147
  162. package/transpiled/react/Viewer/hoc/withFileUrl.js +0 -207
  163. package/transpiled/react/Viewer/hoc/withViewerLocales.js +0 -3
  164. package/transpiled/react/Viewer/hooks/useReferencedContactName.js +0 -32
  165. package/transpiled/react/Viewer/index.js +0 -11
  166. package/transpiled/react/Viewer/locales/index.js +0 -136
  167. package/transpiled/react/Viewer/proptypes.js +0 -14
  168. package/transpiled/react/Viewer/providers/ActionMenuProvider.js +0 -34
  169. package/transpiled/react/Viewer/queries.js +0 -26
  170. /package/react/{Viewer/providers/EncryptedProvider.jsx → providers/Encrypted/index.jsx} +0 -0
  171. /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);