cozy-ui 111.21.0 → 112.1.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 (168) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/package.json +4 -3
  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/hooks/useClientErrors.jsx +140 -0
  7. package/react/hooks/useClientErrors.spec.jsx +102 -0
  8. package/react/index.js +0 -1
  9. package/transpiled/react/FileImageLoader/index.js +3 -3
  10. package/transpiled/react/hooks/useClientErrors.js +167 -0
  11. package/transpiled/react/index.js +0 -1
  12. package/transpiled/react/stylesheet.css +1 -1
  13. package/react/Viewer/Footer/BottomSheetContent.jsx +0 -29
  14. package/react/Viewer/Footer/DownloadButton.jsx +0 -67
  15. package/react/Viewer/Footer/FooterActionButtons.jsx +0 -22
  16. package/react/Viewer/Footer/FooterActionButtons.spec.jsx +0 -30
  17. package/react/Viewer/Footer/FooterContent.jsx +0 -99
  18. package/react/Viewer/Footer/ForwardButton.jsx +0 -95
  19. package/react/Viewer/Footer/ForwardButton.spec.jsx +0 -87
  20. package/react/Viewer/Footer/ForwardOrDownloadButton.jsx +0 -24
  21. package/react/Viewer/Footer/Sharing.jsx +0 -60
  22. package/react/Viewer/Footer/helpers.js +0 -107
  23. package/react/Viewer/Footer/helpers.spec.js +0 -77
  24. package/react/Viewer/NoViewer/DownloadButton.jsx +0 -28
  25. package/react/Viewer/NoViewer/FileIcon.jsx +0 -46
  26. package/react/Viewer/NoViewer/NoViewer.jsx +0 -29
  27. package/react/Viewer/NoViewer/NoViewer.spec.jsx +0 -44
  28. package/react/Viewer/NoViewer/__snapshots__/NoViewer.spec.jsx.snap +0 -82
  29. package/react/Viewer/NoViewer/index.jsx +0 -1
  30. package/react/Viewer/Panel/ActionMenuDesktop.jsx +0 -66
  31. package/react/Viewer/Panel/ActionMenuMobile.jsx +0 -74
  32. package/react/Viewer/Panel/ActionMenuWrapper.jsx +0 -104
  33. package/react/Viewer/Panel/Certifications.jsx +0 -62
  34. package/react/Viewer/Panel/PanelContent.jsx +0 -49
  35. package/react/Viewer/Panel/Qualification.jsx +0 -114
  36. package/react/Viewer/Panel/QualificationListItemContact.jsx +0 -85
  37. package/react/Viewer/Panel/QualificationListItemDate.jsx +0 -77
  38. package/react/Viewer/Panel/QualificationListItemInformation.jsx +0 -68
  39. package/react/Viewer/Panel/QualificationListItemInformation.spec.jsx +0 -73
  40. package/react/Viewer/Panel/QualificationListItemOther.jsx +0 -61
  41. package/react/Viewer/Panel/QualificationListItemText.jsx +0 -30
  42. package/react/Viewer/Panel/getPanelBlocks.jsx +0 -56
  43. package/react/Viewer/Panel/getPanelBlocks.spec.jsx +0 -79
  44. package/react/Viewer/Panel/styles.styl +0 -13
  45. package/react/Viewer/Readme.md +0 -352
  46. package/react/Viewer/Viewer.jsx +0 -134
  47. package/react/Viewer/ViewerContainer.jsx +0 -169
  48. package/react/Viewer/ViewerExposer.js +0 -3
  49. package/react/Viewer/ViewerInformationsWrapper.jsx +0 -69
  50. package/react/Viewer/ViewerInformationsWrapper.spec.jsx +0 -63
  51. package/react/Viewer/ViewerWithCustomPanelAndFooter.jsx +0 -55
  52. package/react/Viewer/ViewersByFile/AudioViewer.jsx +0 -21
  53. package/react/Viewer/ViewersByFile/AudioViewer.spec.jsx +0 -39
  54. package/react/Viewer/ViewersByFile/BlankPaperViewer.jsx +0 -46
  55. package/react/Viewer/ViewersByFile/ImageViewer.jsx +0 -330
  56. package/react/Viewer/ViewersByFile/ImageViewer.spec.jsx +0 -70
  57. package/react/Viewer/ViewersByFile/NoNetworkViewer.jsx +0 -17
  58. package/react/Viewer/ViewersByFile/OnlyOfficeViewer.jsx +0 -28
  59. package/react/Viewer/ViewersByFile/PdfJsViewer.jsx +0 -210
  60. package/react/Viewer/ViewersByFile/PdfJsViewer.spec.jsx +0 -160
  61. package/react/Viewer/ViewersByFile/PdfMobileViewer.jsx +0 -106
  62. package/react/Viewer/ViewersByFile/PdfMobileViewer.spec.jsx +0 -76
  63. package/react/Viewer/ViewersByFile/ShortcutViewer.jsx +0 -38
  64. package/react/Viewer/ViewersByFile/ShortcutViewer.spec.jsx +0 -32
  65. package/react/Viewer/ViewersByFile/TextViewer.jsx +0 -126
  66. package/react/Viewer/ViewersByFile/TextViewer.spec.jsx +0 -118
  67. package/react/Viewer/ViewersByFile/VideoViewer.jsx +0 -13
  68. package/react/Viewer/ViewersByFile/VideoViewer.spec.jsx +0 -39
  69. package/react/Viewer/ViewersByFile/__snapshots__/AudioViewer.spec.jsx.snap +0 -43
  70. package/react/Viewer/ViewersByFile/__snapshots__/ShortcutViewer.spec.jsx.snap +0 -57
  71. package/react/Viewer/ViewersByFile/__snapshots__/TextViewer.spec.jsx.snap +0 -100
  72. package/react/Viewer/ViewersByFile/__snapshots__/VideoViewer.spec.jsx.snap +0 -19
  73. package/react/Viewer/ViewersByFile/styles.styl +0 -87
  74. package/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
  75. package/react/Viewer/components/ExpirationAlert.jsx +0 -86
  76. package/react/Viewer/components/ExpirationAnnotation.jsx +0 -40
  77. package/react/Viewer/components/Footer.jsx +0 -13
  78. package/react/Viewer/components/InformationPanel.jsx +0 -26
  79. package/react/Viewer/components/Navigation.jsx +0 -39
  80. package/react/Viewer/components/PdfToolbarButton.jsx +0 -26
  81. package/react/Viewer/components/PrintButton.jsx +0 -90
  82. package/react/Viewer/components/Toolbar.jsx +0 -111
  83. package/react/Viewer/components/ToolbarButtons.jsx +0 -11
  84. package/react/Viewer/components/ToolbarFilePath.jsx +0 -61
  85. package/react/Viewer/components/ViewerByFile.jsx +0 -112
  86. package/react/Viewer/components/ViewerByFile.spec.jsx +0 -100
  87. package/react/Viewer/components/ViewerControls.jsx +0 -190
  88. package/react/Viewer/components/ViewerControls.spec.jsx +0 -54
  89. package/react/Viewer/components/ViewerSpinner.jsx +0 -17
  90. package/react/Viewer/components/styles.styl +0 -93
  91. package/react/Viewer/helpers.js +0 -131
  92. package/react/Viewer/helpers.spec.js +0 -136
  93. package/react/Viewer/hoc/withFileUrl.jsx +0 -93
  94. package/react/Viewer/hoc/withViewerLocales.jsx +0 -4
  95. package/react/Viewer/hooks/useReferencedContactName.jsx +0 -26
  96. package/react/Viewer/index.jsx +0 -12
  97. package/react/Viewer/locales/en.json +0 -66
  98. package/react/Viewer/locales/fr.json +0 -66
  99. package/react/Viewer/locales/index.js +0 -4
  100. package/react/Viewer/proptypes.js +0 -12
  101. package/react/Viewer/providers/ActionMenuProvider.jsx +0 -35
  102. package/react/Viewer/queries.js +0 -20
  103. package/react/Viewer/styles.styl +0 -22
  104. package/react/Viewer/vars.styl +0 -6
  105. package/transpiled/react/Viewer/Footer/BottomSheetContent.js +0 -28
  106. package/transpiled/react/Viewer/Footer/DownloadButton.js +0 -91
  107. package/transpiled/react/Viewer/Footer/FooterActionButtons.js +0 -21
  108. package/transpiled/react/Viewer/Footer/FooterContent.js +0 -98
  109. package/transpiled/react/Viewer/Footer/ForwardButton.js +0 -143
  110. package/transpiled/react/Viewer/Footer/ForwardOrDownloadButton.js +0 -25
  111. package/transpiled/react/Viewer/Footer/Sharing.js +0 -57
  112. package/transpiled/react/Viewer/Footer/helpers.js +0 -151
  113. package/transpiled/react/Viewer/NoViewer/DownloadButton.js +0 -34
  114. package/transpiled/react/Viewer/NoViewer/FileIcon.js +0 -57
  115. package/transpiled/react/Viewer/NoViewer/NoViewer.js +0 -49
  116. package/transpiled/react/Viewer/NoViewer/index.js +0 -1
  117. package/transpiled/react/Viewer/Panel/ActionMenuDesktop.js +0 -68
  118. package/transpiled/react/Viewer/Panel/ActionMenuMobile.js +0 -70
  119. package/transpiled/react/Viewer/Panel/ActionMenuWrapper.js +0 -129
  120. package/transpiled/react/Viewer/Panel/Certifications.js +0 -56
  121. package/transpiled/react/Viewer/Panel/PanelContent.js +0 -48
  122. package/transpiled/react/Viewer/Panel/Qualification.js +0 -119
  123. package/transpiled/react/Viewer/Panel/QualificationListItemContact.js +0 -96
  124. package/transpiled/react/Viewer/Panel/QualificationListItemDate.js +0 -64
  125. package/transpiled/react/Viewer/Panel/QualificationListItemInformation.js +0 -59
  126. package/transpiled/react/Viewer/Panel/QualificationListItemOther.js +0 -53
  127. package/transpiled/react/Viewer/Panel/QualificationListItemText.js +0 -29
  128. package/transpiled/react/Viewer/Panel/getPanelBlocks.js +0 -62
  129. package/transpiled/react/Viewer/Viewer.js +0 -172
  130. package/transpiled/react/Viewer/ViewerContainer.js +0 -189
  131. package/transpiled/react/Viewer/ViewerExposer.js +0 -2
  132. package/transpiled/react/Viewer/ViewerInformationsWrapper.js +0 -49
  133. package/transpiled/react/Viewer/ViewerWithCustomPanelAndFooter.js +0 -56
  134. package/transpiled/react/Viewer/ViewersByFile/AudioViewer.js +0 -41
  135. package/transpiled/react/Viewer/ViewersByFile/BlankPaperViewer.js +0 -74
  136. package/transpiled/react/Viewer/ViewersByFile/ImageViewer.js +0 -367
  137. package/transpiled/react/Viewer/ViewersByFile/NoNetworkViewer.js +0 -38
  138. package/transpiled/react/Viewer/ViewersByFile/OnlyOfficeViewer.js +0 -29
  139. package/transpiled/react/Viewer/ViewersByFile/PdfJsViewer.js +0 -254
  140. package/transpiled/react/Viewer/ViewersByFile/PdfMobileViewer.js +0 -153
  141. package/transpiled/react/Viewer/ViewersByFile/ShortcutViewer.js +0 -42
  142. package/transpiled/react/Viewer/ViewersByFile/TextViewer.js +0 -219
  143. package/transpiled/react/Viewer/ViewersByFile/VideoViewer.js +0 -33
  144. package/transpiled/react/Viewer/assets/IlluGenericNewPage.svg +0 -10
  145. package/transpiled/react/Viewer/components/ExpirationAlert.js +0 -100
  146. package/transpiled/react/Viewer/components/ExpirationAnnotation.js +0 -41
  147. package/transpiled/react/Viewer/components/Footer.js +0 -29
  148. package/transpiled/react/Viewer/components/InformationPanel.js +0 -23
  149. package/transpiled/react/Viewer/components/Navigation.js +0 -47
  150. package/transpiled/react/Viewer/components/PdfToolbarButton.js +0 -28
  151. package/transpiled/react/Viewer/components/PrintButton.js +0 -137
  152. package/transpiled/react/Viewer/components/Toolbar.js +0 -115
  153. package/transpiled/react/Viewer/components/ToolbarButtons.js +0 -9
  154. package/transpiled/react/Viewer/components/ToolbarFilePath.js +0 -71
  155. package/transpiled/react/Viewer/components/ViewerByFile.js +0 -105
  156. package/transpiled/react/Viewer/components/ViewerControls.js +0 -226
  157. package/transpiled/react/Viewer/components/ViewerSpinner.js +0 -17
  158. package/transpiled/react/Viewer/helpers.js +0 -147
  159. package/transpiled/react/Viewer/hoc/withFileUrl.js +0 -207
  160. package/transpiled/react/Viewer/hoc/withViewerLocales.js +0 -3
  161. package/transpiled/react/Viewer/hooks/useReferencedContactName.js +0 -32
  162. package/transpiled/react/Viewer/index.js +0 -11
  163. package/transpiled/react/Viewer/locales/index.js +0 -136
  164. package/transpiled/react/Viewer/proptypes.js +0 -14
  165. package/transpiled/react/Viewer/providers/ActionMenuProvider.js +0 -34
  166. package/transpiled/react/Viewer/queries.js +0 -26
  167. /package/react/{Viewer/providers/EncryptedProvider.jsx → providers/Encrypted/index.jsx} +0 -0
  168. /package/transpiled/react/{Viewer/providers/EncryptedProvider.js → providers/Encrypted/index.js} +0 -0
@@ -1,17 +0,0 @@
1
- import React from 'react'
2
-
3
- import styles from './styles.styl'
4
- import Icon from '../../Icon'
5
- import CloudBrokenIcon from '../../Icons/CloudBroken'
6
- import Button from '../../deprecated/Button'
7
- import { withViewerLocales } from '../hoc/withViewerLocales'
8
-
9
- const NoNetworkViewer = ({ t, onReload }) => (
10
- <div className={styles['viewer-canceled']}>
11
- <Icon icon={CloudBrokenIcon} width={160} height={140} />
12
- <h2>{t('Viewer.error.network')}</h2>
13
- <Button onClick={onReload} label={t('Viewer.retry')} />
14
- </div>
15
- )
16
-
17
- export default withViewerLocales(NoNetworkViewer)
@@ -1,28 +0,0 @@
1
- import PropTypes from 'prop-types'
2
- import React from 'react'
3
-
4
- import Button from '../../deprecated/Button'
5
- import { FileDoctype } from '../../proptypes'
6
- import NoViewer from '../NoViewer'
7
- import { withViewerLocales } from '../hoc/withViewerLocales'
8
-
9
- const OnlyOfficeViewer = ({ file, onlyOfficeOpener, t }) => {
10
- return (
11
- <NoViewer
12
- file={file}
13
- renderFallbackExtraContent={() => (
14
- <Button
15
- label={t('Viewer.openInOnlyOffice')}
16
- onClick={() => onlyOfficeOpener(file)}
17
- />
18
- )}
19
- />
20
- )
21
- }
22
-
23
- OnlyOfficeViewer.propTypes = {
24
- file: FileDoctype,
25
- onlyOfficeOpener: PropTypes.func.isRequired
26
- }
27
-
28
- export default withViewerLocales(OnlyOfficeViewer)
@@ -1,210 +0,0 @@
1
- import cx from 'classnames'
2
- import flow from 'lodash/flow'
3
- import throttle from 'lodash/throttle'
4
- import PropTypes from 'prop-types'
5
- import React, { Component } from 'react'
6
- import { Document, Page } from 'react-pdf'
7
-
8
- import styles from './styles.styl'
9
- import NoViewer from '../NoViewer'
10
- import ToolbarButton from '../components/PdfToolbarButton'
11
- import ViewerSpinner from '../components/ViewerSpinner'
12
- import withFileUrl from '../hoc/withFileUrl'
13
- import { withViewerLocales } from '../hoc/withViewerLocales'
14
-
15
- export const MIN_SCALE = 0.25
16
- export const MAX_SCALE = 3
17
- export const MAX_PAGES = 3
18
- const KEY_CODE_UP = 38
19
- const KEY_CODE_DOWN = 40
20
-
21
- export class PdfJsViewer extends Component {
22
- state = {
23
- totalPages: 1,
24
- scale: 1,
25
- currentPage: 1,
26
- loaded: false,
27
- errored: false,
28
- width: null,
29
- renderAllPages: false
30
- }
31
-
32
- componentDidMount() {
33
- this.setWrapperSize()
34
- this.resizeListener = throttle(this.setWrapperSize, 500)
35
- window.addEventListener('resize', this.resizeListener)
36
- document.addEventListener('keyup', this.onKeyUp, false)
37
- }
38
-
39
- componentWillUnmount() {
40
- window.removeEventListener('resize', this.resizeListener)
41
- document.removeEventListener('keyup', this.onKeyUp, false)
42
- }
43
-
44
- onKeyUp = e => {
45
- if (e.keyCode === KEY_CODE_UP) this.previousPage()
46
- else if (e.keyCode === KEY_CODE_DOWN) this.nextPage()
47
- }
48
-
49
- toggleGestures(enable) {
50
- if (!this.props.gestures) return
51
- this.props.gestures.get('swipe').set({ enable })
52
- this.props.gestures.get('pan').set({ enable })
53
- }
54
-
55
- setWrapperSize = () => {
56
- const width = this.wrapper
57
- ? this.wrapper.getBoundingClientRect().width
58
- : null
59
- this.setState({ width })
60
- }
61
-
62
- onLoadSuccess = ({ numPages }) => {
63
- this.setState({
64
- totalPages: numPages,
65
- renderAllPages: numPages <= MAX_PAGES,
66
- loaded: true
67
- })
68
- }
69
-
70
- onLoadError = error => {
71
- // eslint-disable-next-line no-console
72
- console.warn(error)
73
- this.setState({
74
- errored: true
75
- })
76
- }
77
-
78
- nextPage = () => {
79
- this.setState(state => ({
80
- currentPage: Math.min(state.currentPage + 1, state.totalPages)
81
- }))
82
- }
83
-
84
- previousPage = () => {
85
- this.setState(state => ({
86
- currentPage: Math.max(state.currentPage - 1, 1)
87
- }))
88
- }
89
-
90
- scaleUp = () => {
91
- this.setState(state => {
92
- const previousScale = state.scale
93
- const scale = Math.min(previousScale + 0.25, MAX_SCALE)
94
- if (scale > 1 && previousScale <= 1) this.toggleGestures(false)
95
- return {
96
- scale
97
- }
98
- })
99
- }
100
-
101
- scaleDown = () => {
102
- this.setState(state => {
103
- const previousScale = state.scale
104
- const scale = Math.max(previousScale - 0.25, MIN_SCALE)
105
- if (scale <= 1 && previousScale > 1) this.toggleGestures(true)
106
- return {
107
- scale
108
- }
109
- })
110
- }
111
-
112
- render() {
113
- const { url, file, renderFallbackExtraContent, t } = this.props
114
- const {
115
- loaded,
116
- errored,
117
- totalPages,
118
- currentPage,
119
- scale,
120
- width,
121
- renderAllPages
122
- } = this.state
123
- if (errored)
124
- return (
125
- <NoViewer
126
- file={file}
127
- renderFallbackExtraContent={renderFallbackExtraContent}
128
- />
129
- )
130
- const pageWidth = width ? width * scale : null // newer versions of react-pdf do that automatically
131
-
132
- return (
133
- <div
134
- className={styles['viewer-pdfviewer']}
135
- ref={ref => (this.wrapper = ref)}
136
- >
137
- <Document
138
- file={url}
139
- onLoadSuccess={this.onLoadSuccess}
140
- onLoadError={this.onLoadError}
141
- className={styles['viewer-pdfviewer-pdf']}
142
- loading={<ViewerSpinner />}
143
- >
144
- {renderAllPages ? (
145
- [...Array(totalPages)].map((_, page) => (
146
- <Page
147
- key={page}
148
- pageNumber={page + 1}
149
- width={pageWidth}
150
- renderAnnotations={false}
151
- className={cx('u-mv-1', styles['viewer-pdfviewer-page'])}
152
- />
153
- ))
154
- ) : (
155
- <Page
156
- pageNumber={currentPage}
157
- width={pageWidth}
158
- renderAnnotations={false}
159
- className={styles['viewer-pdfviewer-page']}
160
- />
161
- )}
162
- </Document>
163
- {loaded && (
164
- <div className={cx(styles['viewer-pdfviewer-toolbar'], 'u-p-half')}>
165
- {!renderAllPages && (
166
- <span className="u-mh-half">
167
- <ToolbarButton
168
- icon="top"
169
- onClick={this.previousPage}
170
- disabled={currentPage === 1}
171
- label={t('Viewer.previous')}
172
- />
173
- {currentPage}/{totalPages}
174
- <ToolbarButton
175
- icon="bottom"
176
- onClick={this.nextPage}
177
- disabled={currentPage === totalPages}
178
- label={t('Viewer.next')}
179
- />
180
- </span>
181
- )}
182
-
183
- <span className="u-mh-half">
184
- <ToolbarButton
185
- icon="dash"
186
- onClick={this.scaleDown}
187
- disabled={scale === MIN_SCALE}
188
- label={t('Viewer.scaledown')}
189
- />
190
- <ToolbarButton
191
- icon="plus"
192
- onClick={this.scaleUp}
193
- disabled={scale === MAX_SCALE}
194
- label={t('Viewer.scaleup')}
195
- />
196
- </span>
197
- </div>
198
- )}
199
- </div>
200
- )
201
- }
202
- }
203
-
204
- PdfJsViewer.propTypes = {
205
- url: PropTypes.string.isRequired,
206
- gestures: PropTypes.object,
207
- renderFallbackExtraContent: PropTypes.func
208
- }
209
-
210
- export default flow(withFileUrl, withViewerLocales)(PdfJsViewer)
@@ -1,160 +0,0 @@
1
- import { shallow } from 'enzyme'
2
- import React from 'react'
3
-
4
- import { PdfJsViewer, MIN_SCALE, MAX_SCALE, MAX_PAGES } from './PdfJsViewer'
5
-
6
- describe('PDFViewer', () => {
7
- let component
8
- const panGestureMock = jest.fn()
9
- const swipeGestureMock = jest.fn()
10
- const gesturesMock = {
11
- get: jest.fn(type => ({
12
- set: type === 'pan' ? panGestureMock : swipeGestureMock
13
- }))
14
- }
15
- beforeEach(() => {
16
- component = shallow(
17
- <PdfJsViewer url="test" file={{}} gestures={gesturesMock} t={x => x} />
18
- )
19
- })
20
- afterEach(() => {
21
- jest.clearAllMocks()
22
- })
23
-
24
- describe('desture integration', () => {
25
- let instance
26
- beforeEach(() => {
27
- instance = component.instance()
28
- })
29
-
30
- it('should disable gestures when zooming in', () => {
31
- instance.scaleUp()
32
- expect(component.state('scale')).toBeGreaterThan(1)
33
- expect(panGestureMock).toHaveBeenCalledWith({ enable: false })
34
- expect(swipeGestureMock).toHaveBeenCalledWith({ enable: false })
35
- instance.scaleUp()
36
- expect(panGestureMock).toHaveBeenCalledTimes(1)
37
- expect(swipeGestureMock).toHaveBeenCalledTimes(1)
38
- })
39
-
40
- it('should leave gestures alone when zooming out', () => {
41
- instance.scaleDown()
42
- expect(component.state('scale')).toBeLessThan(1)
43
- expect(panGestureMock).not.toHaveBeenCalled()
44
- expect(swipeGestureMock).not.toHaveBeenCalled()
45
- })
46
-
47
- it('should re-enable gestures when zooming back out', () => {
48
- instance.scaleUp()
49
- expect(component.state('scale')).toBeGreaterThan(1)
50
- expect(panGestureMock).toHaveBeenCalledWith({ enable: false })
51
- expect(swipeGestureMock).toHaveBeenCalledWith({ enable: false })
52
- instance.scaleDown()
53
- expect(component.state('scale')).toBe(1)
54
- expect(panGestureMock).toHaveBeenCalledWith({ enable: true })
55
- expect(swipeGestureMock).toHaveBeenCalledWith({ enable: true })
56
- })
57
- })
58
-
59
- describe('with a valid PDF', () => {
60
- let instance
61
- beforeEach(() => {
62
- instance = component.instance()
63
- instance.onLoadSuccess({ numPages: 3 })
64
- })
65
-
66
- it('should start with default options', () => {
67
- expect(component.state('loaded')).toBe(true)
68
- expect(component.state('totalPages')).toBe(3)
69
- expect(component.state('currentPage')).toBe(1)
70
- expect(component.state('scale')).toBe(1)
71
- })
72
-
73
- it('should flip to the next page while possible', () => {
74
- instance.nextPage()
75
- expect(component.state('currentPage')).toBe(2)
76
- instance.nextPage()
77
- expect(component.state('currentPage')).toBe(3)
78
- instance.nextPage()
79
- expect(component.state('currentPage')).toBe(3)
80
- })
81
-
82
- it('should flip to the previous page while possible', () => {
83
- instance.nextPage()
84
- expect(component.state('currentPage')).toBe(2)
85
- instance.previousPage()
86
- expect(component.state('currentPage')).toBe(1)
87
- instance.previousPage()
88
- expect(component.state('currentPage')).toBe(1)
89
- })
90
-
91
- it('should scale up to a certain point', () => {
92
- const initialScale = component.state('scale')
93
- instance.scaleUp()
94
- expect(component.state('scale')).toBeGreaterThan(initialScale)
95
-
96
- for (let i = 0; i < 10; i++) instance.scaleUp()
97
- expect(component.state('scale')).toEqual(MAX_SCALE)
98
- })
99
-
100
- it('should scale down to a certain point', () => {
101
- const initialScale = component.state('scale')
102
- instance.scaleDown()
103
- expect(component.state('scale')).toBeLessThan(initialScale)
104
-
105
- for (let i = 0; i < 10; i++) instance.scaleDown()
106
- expect(component.state('scale')).toEqual(MIN_SCALE)
107
- })
108
- })
109
-
110
- describe('a PDF with few pages', () => {
111
- beforeEach(() => {
112
- component.instance().onLoadSuccess({ numPages: MAX_PAGES })
113
- })
114
-
115
- it('should render all the pages', () => {
116
- const pages = component.find('ForwardRef(Page)')
117
- expect(pages.length).toEqual(MAX_PAGES)
118
- })
119
-
120
- it('should not show pagination controls', () => {
121
- const pageUp = component.find({ icon: 'top' })
122
- const pageDown = component.find({ icon: 'bottom' })
123
- expect(pageUp.length).toEqual(0)
124
- expect(pageDown.length).toEqual(0)
125
- })
126
- })
127
-
128
- describe('a PDF with many pages', () => {
129
- beforeEach(() => {
130
- component.instance().onLoadSuccess({ numPages: MAX_PAGES + 1 })
131
- })
132
-
133
- it('should render only the current page', () => {
134
- const pages = component.find('ForwardRef(Page)')
135
- expect(pages.length).toEqual(1)
136
- })
137
-
138
- it('should show pagination controls', () => {
139
- const pageUp = component.find({ icon: 'top' })
140
- const pageDown = component.find({ icon: 'bottom' })
141
- expect(pageUp.length).toEqual(1)
142
- expect(pageDown.length).toEqual(1)
143
- })
144
- })
145
-
146
- describe('with a pdf that does not load', () => {
147
- beforeEach(() => {
148
- jest.spyOn(console, 'warn').mockImplementation(() => {})
149
- })
150
- afterEach(() => {
151
- console.warn.mockRestore()
152
- })
153
- it('should show a fallback', () => {
154
- component.instance().onLoadError('pdfviewer test error')
155
- expect(component.state('errored')).toBe(true)
156
- const noViewer = component.find('NoViewer')
157
- expect(noViewer.length).toBe(1)
158
- })
159
- })
160
- })
@@ -1,106 +0,0 @@
1
- import PropTypes from 'prop-types'
2
- import React, { useState, useEffect, useRef, useCallback } from 'react'
3
-
4
- import { useClient } from 'cozy-client'
5
-
6
- import styles from './styles.styl'
7
- import FileImageLoader from '../../FileImageLoader'
8
- import Spinner from '../../Spinner'
9
- import { FileDoctype } from '../../proptypes'
10
- import { useAlert } from '../../providers/Alert'
11
- import NoViewer from '../NoViewer'
12
- import DownloadButton from '../NoViewer/DownloadButton'
13
- import { withViewerLocales } from '../hoc/withViewerLocales'
14
-
15
- export const PdfMobileViewer = ({ file, url, t, gestures }) => {
16
- const [loading, setLoading] = useState(true)
17
- const [error, setError] = useState(false)
18
- const imgRef = useRef(null)
19
- const { showAlert } = useAlert()
20
-
21
- const client = useClient()
22
-
23
- const onImageError = () => {
24
- setLoading(false)
25
- setError(true)
26
- }
27
-
28
- const onImageLoad = () => {
29
- setLoading(false)
30
- }
31
-
32
- const handleOnClick = useCallback(
33
- async file => {
34
- try {
35
- await client.collection('io.cozy.files').download(file)
36
- } catch (error) {
37
- showAlert({
38
- message: t('Viewer.error.generic'),
39
- severity: 'error',
40
- variant: 'filled',
41
- icon: false
42
- })
43
- }
44
- },
45
- [client, showAlert, t]
46
- )
47
-
48
- useEffect(() => {
49
- if (gestures) {
50
- gestures.get('pinch').set({ enable: true })
51
- gestures.on('pinchend tap', evt => {
52
- if (
53
- (evt.type === 'pinchend' || evt.tapCount === 1) &&
54
- evt.target === imgRef.current
55
- ) {
56
- handleOnClick(file)
57
- }
58
- })
59
-
60
- return () => {
61
- gestures.off('pinchend tap')
62
- }
63
- }
64
- }, [client, gestures, file, handleOnClick])
65
-
66
- if (error) {
67
- return (
68
- <NoViewer
69
- file={file}
70
- renderFallbackExtraContent={file => <DownloadButton file={file} />}
71
- />
72
- )
73
- }
74
-
75
- return (
76
- <div className={styles['viewer-pdfMobile']}>
77
- {loading && <Spinner size="xxlarge" middle noMargin />}
78
- {file && (
79
- <FileImageLoader
80
- file={file}
81
- url={url}
82
- linkType="medium"
83
- onError={onImageError}
84
- key={file.id}
85
- render={src => (
86
- <img
87
- ref={imgRef}
88
- className={styles['viewer-pdfMobile--image']}
89
- alt={file.name}
90
- src={src}
91
- onLoad={onImageLoad}
92
- />
93
- )}
94
- />
95
- )}
96
- </div>
97
- )
98
- }
99
-
100
- PdfMobileViewer.prototype = {
101
- file: FileDoctype.isRequired,
102
- url: PropTypes.string,
103
- gestures: PropTypes.object
104
- }
105
-
106
- export default withViewerLocales(PdfMobileViewer)
@@ -1,76 +0,0 @@
1
- import { render, waitFor } from '@testing-library/react'
2
- import React from 'react'
3
-
4
- import { CozyProvider, createMockClient } from 'cozy-client'
5
- import logger from 'cozy-logger'
6
-
7
- import { PdfMobileViewer } from './PdfMobileViewer'
8
- import { I18n } from '../../providers/I18n'
9
- import EncryptedProvider from '../providers/EncryptedProvider'
10
-
11
- logger.error = logger.warn = jest.fn()
12
-
13
- const client = createMockClient({})
14
- client.collection = jest.fn(() => ({
15
- getDownloadLinkById: jest.fn()
16
- }))
17
- client.plugins.realtime = {
18
- subscribe: jest.fn(),
19
- unsubscribe: jest.fn(),
20
- unsubscribeAll: jest.fn()
21
- }
22
- jest.mock('../../providers/Alert', () => ({
23
- useAlert: jest.fn().mockReturnValue({ showAlert: jest.fn() })
24
- }))
25
-
26
- const file = {
27
- _id: 'pdf',
28
- class: 'pdf',
29
- name: 'Demo.pdf',
30
- mime: 'application/pdf',
31
- links: {
32
- medium: 'https://viewerdemo.cozycloud.cc/IMG_0062.PNG'
33
- }
34
- }
35
-
36
- const setup = ({ file }) => {
37
- const root = render(
38
- <CozyProvider client={client}>
39
- <I18n lang="en" dictRequire={() => ''}>
40
- <EncryptedProvider>
41
- <PdfMobileViewer file={file} t={x => x} />
42
- </EncryptedProvider>
43
- </I18n>
44
- </CozyProvider>
45
- )
46
-
47
- return { root }
48
- }
49
-
50
- describe('PdfMobileViewer', () => {
51
- it('should show a spinner if image is not loaded', () => {
52
- const { root } = setup({ file })
53
- const { getByRole } = root
54
-
55
- expect(getByRole('progressbar'))
56
- })
57
-
58
- describe('errors if file as no medium or failed to download', () => {
59
- let fileWithoutLinks = file
60
-
61
- beforeAll(() => {
62
- fileWithoutLinks.links = undefined
63
- })
64
-
65
- it('should show "download" button on browser', async () => {
66
- const { root } = setup({ file: fileWithoutLinks })
67
- const { getByText, queryByRole } = root
68
-
69
- await waitFor(() => {
70
- expect(queryByRole('progressbar')).toBeFalsy()
71
- expect(getByText('Viewer.download'))
72
- expect(getByText(file.name))
73
- })
74
- })
75
- })
76
- })
@@ -1,38 +0,0 @@
1
- import get from 'lodash/get'
2
- import React from 'react'
3
-
4
- import { useClient, useFetchShortcut } from 'cozy-client'
5
-
6
- import OpenwithIcon from '../../Icons/Openwith'
7
- import { ButtonLink } from '../../deprecated/Button'
8
- import { FileDoctype } from '../../proptypes'
9
- import NoViewer from '../NoViewer'
10
- import { withViewerLocales } from '../hoc/withViewerLocales'
11
-
12
- const ShortcutViewer = ({ t, file }) => {
13
- const client = useClient()
14
- const { shortcutInfos } = useFetchShortcut(client, file.id)
15
- let url = ''
16
- if (shortcutInfos) {
17
- url = new URL(get(shortcutInfos, 'data.attributes.url'))
18
- }
19
- return (
20
- <NoViewer
21
- file={file}
22
- renderFallbackExtraContent={() => (
23
- <ButtonLink
24
- label={`${t('Viewer.goto', { url: get(url, 'origin', '') })}`}
25
- icon={OpenwithIcon}
26
- href={`${get(url, 'origin', '')}`}
27
- target="_blank"
28
- />
29
- )}
30
- />
31
- )
32
- }
33
-
34
- ShortcutViewer.propTypes = {
35
- file: FileDoctype.isRequired
36
- }
37
-
38
- export default withViewerLocales(ShortcutViewer)
@@ -1,32 +0,0 @@
1
- import { render, waitFor } from '@testing-library/react'
2
- import React from 'react'
3
-
4
- import CozyClient, { CozyProvider } from 'cozy-client'
5
-
6
- import ShortcutViewer from './ShortcutViewer'
7
- import I18n from '../../providers/I18n'
8
- import en from '../locales/en.json'
9
-
10
- export const locales = {
11
- en
12
- }
13
-
14
- const setup = () => {
15
- const client = new CozyClient({})
16
- return (
17
- <CozyProvider client={client}>
18
- <I18n lang="en" dictRequire={() => locales['en']}>
19
- <ShortcutViewer file={{ id: '1' }} />
20
- </I18n>
21
- </CozyProvider>
22
- )
23
- }
24
-
25
- describe('Shortcutviewer', () => {
26
- it('renders the component', async () => {
27
- const { container } = render(setup())
28
- await waitFor(() => {
29
- expect(container).toMatchSnapshot()
30
- })
31
- })
32
- })