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,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
- })