cozy-bar 1.17.1

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 (181) hide show
  1. package/.eslintrc.json +7 -0
  2. package/.github/auto-merge.yml +7 -0
  3. package/.nvmrc +1 -0
  4. package/.transifexrc.tpl +4 -0
  5. package/.travis.yml +28 -0
  6. package/.tx/config +8 -0
  7. package/CHANGELOG.md +493 -0
  8. package/CODEOWNERS +2 -0
  9. package/CONTRIBUTING.md +135 -0
  10. package/LICENSE +21 -0
  11. package/README.md +172 -0
  12. package/babel.config.js +3 -0
  13. package/config/aliases/globalReact.js +1 -0
  14. package/config/aliases/globalReactDOM.js +1 -0
  15. package/config/webpack.config.analyzer.js +10 -0
  16. package/config/webpack.config.base.js +61 -0
  17. package/config/webpack.config.dev.js +16 -0
  18. package/config/webpack.config.extract.js +84 -0
  19. package/config/webpack.config.inline-styles.js +82 -0
  20. package/config/webpack.config.jsx.js +14 -0
  21. package/config/webpack.config.prod.js +18 -0
  22. package/config/webpack.js +31 -0
  23. package/config/webpack.vars.js +11 -0
  24. package/dist/cozy-bar.css +9445 -0
  25. package/dist/cozy-bar.css.map +1 -0
  26. package/dist/cozy-bar.js +122668 -0
  27. package/dist/cozy-bar.js.map +1 -0
  28. package/dist/cozy-bar.min.css +9 -0
  29. package/dist/cozy-bar.min.css.map +1 -0
  30. package/dist/cozy-bar.min.js +57 -0
  31. package/dist/cozy-bar.min.js.map +1 -0
  32. package/dist/cozy-bar.mobile.js +123719 -0
  33. package/dist/cozy-bar.mobile.js.map +1 -0
  34. package/dist/cozy-bar.mobile.min.js +57 -0
  35. package/dist/cozy-bar.mobile.min.js.map +1 -0
  36. package/docs/dev.md +20 -0
  37. package/examples/Procfile +3 -0
  38. package/examples/icon.png +0 -0
  39. package/examples/index.html +7 -0
  40. package/examples/index.jsx +122 -0
  41. package/examples/logs.js +3 -0
  42. package/package.json +163 -0
  43. package/postcss.config.js +23 -0
  44. package/public/fonts/Lato-Bold.woff2 +0 -0
  45. package/public/fonts/Lato-Regular.woff2 +0 -0
  46. package/public/fonts.css +13 -0
  47. package/public/icon-type-folder-32.png +0 -0
  48. package/public/index.html +63 -0
  49. package/renovate.json +5 -0
  50. package/src/assets/icons/16/icon-claudy.svg +5 -0
  51. package/src/assets/icons/16/icon-cozy-16.svg +1 -0
  52. package/src/assets/icons/16/icon-cube-16.svg +6 -0
  53. package/src/assets/icons/16/icon-logout-16.svg +3 -0
  54. package/src/assets/icons/16/icon-magnifier-16.svg +6 -0
  55. package/src/assets/icons/16/icon-people-16.svg +3 -0
  56. package/src/assets/icons/16/icon-phone-16.svg +3 -0
  57. package/src/assets/icons/16/icon-question-mark-16.svg +3 -0
  58. package/src/assets/icons/16/icon-storage-16.svg +3 -0
  59. package/src/assets/icons/24/icon-arrow-left.svg +3 -0
  60. package/src/assets/icons/32/icon-claudy.svg +1 -0
  61. package/src/assets/icons/apps/icon-collect.svg +25 -0
  62. package/src/assets/icons/apps/icon-drive.svg +17 -0
  63. package/src/assets/icons/apps/icon-market-soon.svg +25 -0
  64. package/src/assets/icons/apps/icon-photos.svg +19 -0
  65. package/src/assets/icons/apps/icon-soon.svg +21 -0
  66. package/src/assets/icons/apps/icon-store.svg +19 -0
  67. package/src/assets/icons/claudyActions/icon-bills.svg +6 -0
  68. package/src/assets/icons/claudyActions/icon-laptop.svg +7 -0
  69. package/src/assets/icons/claudyActions/icon-phone.svg +8 -0
  70. package/src/assets/icons/claudyActions/icon-question-mark.svg +6 -0
  71. package/src/assets/icons/comingsoon/icon-bank.svg +12 -0
  72. package/src/assets/icons/comingsoon/icon-sante.svg +12 -0
  73. package/src/assets/icons/comingsoon/icon-store.svg +6 -0
  74. package/src/assets/icons/icon-cozy.svg +3 -0
  75. package/src/assets/icons/icon-shield.svg +3 -0
  76. package/src/assets/icons/spinner.svg +4 -0
  77. package/src/assets/sprites/icon-apps.svg +1 -0
  78. package/src/assets/sprites/icon-cozy-home.svg +16 -0
  79. package/src/components/Apps/AppItem.jsx +117 -0
  80. package/src/components/Apps/AppItemPlaceholder.jsx +12 -0
  81. package/src/components/Apps/AppNavButtons.jsx +88 -0
  82. package/src/components/Apps/AppsContent.jsx +89 -0
  83. package/src/components/Apps/ButtonCozyHome.jsx +30 -0
  84. package/src/components/Apps/ButtonCozyHome.spec.jsx +53 -0
  85. package/src/components/Apps/IconCozyHome.jsx +24 -0
  86. package/src/components/Apps/index.jsx +81 -0
  87. package/src/components/Banner.jsx +41 -0
  88. package/src/components/Bar.jsx +293 -0
  89. package/src/components/Bar.spec.jsx +133 -0
  90. package/src/components/Claudy.jsx +81 -0
  91. package/src/components/Drawer.jsx +227 -0
  92. package/src/components/Drawer.spec.jsx +98 -0
  93. package/src/components/SearchBar.jsx +358 -0
  94. package/src/components/Settings/SettingsContent.jsx +145 -0
  95. package/src/components/Settings/StorageData.jsx +29 -0
  96. package/src/components/Settings/helper.js +8 -0
  97. package/src/components/Settings/index.jsx +218 -0
  98. package/src/components/SupportModal.jsx +59 -0
  99. package/src/components/__snapshots__/Bar.spec.jsx.snap +302 -0
  100. package/src/config/claudyActions.yaml +14 -0
  101. package/src/config/persistWhitelist.yaml +2 -0
  102. package/src/dom.js +80 -0
  103. package/src/index.jsx +235 -0
  104. package/src/index.spec.jsx +34 -0
  105. package/src/lib/api/helpers.js +13 -0
  106. package/src/lib/api/index.jsx +145 -0
  107. package/src/lib/exceptions.js +89 -0
  108. package/src/lib/expiringMemoize.js +13 -0
  109. package/src/lib/icon.js +77 -0
  110. package/src/lib/importIcons.js +14 -0
  111. package/src/lib/intents.js +16 -0
  112. package/src/lib/logger.js +6 -0
  113. package/src/lib/middlewares/appsI18n.js +57 -0
  114. package/src/lib/realtime.js +43 -0
  115. package/src/lib/reducers/apps.js +175 -0
  116. package/src/lib/reducers/apps.spec.js +59 -0
  117. package/src/lib/reducers/content.js +50 -0
  118. package/src/lib/reducers/context.js +83 -0
  119. package/src/lib/reducers/index.js +73 -0
  120. package/src/lib/reducers/locale.js +22 -0
  121. package/src/lib/reducers/settings.js +111 -0
  122. package/src/lib/reducers/theme.js +48 -0
  123. package/src/lib/reducers/unserializable.js +26 -0
  124. package/src/lib/stack-client.js +401 -0
  125. package/src/lib/stack.js +79 -0
  126. package/src/lib/store/index.js +54 -0
  127. package/src/locales/de.json +57 -0
  128. package/src/locales/en.json +57 -0
  129. package/src/locales/es.json +57 -0
  130. package/src/locales/fr.json +57 -0
  131. package/src/locales/it.json +57 -0
  132. package/src/locales/ja.json +57 -0
  133. package/src/locales/nl_NL.json +57 -0
  134. package/src/locales/pl.json +57 -0
  135. package/src/locales/ru.json +57 -0
  136. package/src/locales/sq.json +57 -0
  137. package/src/locales/zh_CN.json +57 -0
  138. package/src/proptypes/index.js +10 -0
  139. package/src/queries/index.js +16 -0
  140. package/src/styles/apps.css +248 -0
  141. package/src/styles/banner.css +64 -0
  142. package/src/styles/bar.css +106 -0
  143. package/src/styles/base.css +41 -0
  144. package/src/styles/claudy.css +99 -0
  145. package/src/styles/drawer.css +126 -0
  146. package/src/styles/index.styl +33 -0
  147. package/src/styles/indicators.css +58 -0
  148. package/src/styles/nav.css +81 -0
  149. package/src/styles/navigation_item.css +39 -0
  150. package/src/styles/searchbar.css +158 -0
  151. package/src/styles/settings.css +44 -0
  152. package/src/styles/storage.css +22 -0
  153. package/src/styles/supportModal.css +20 -0
  154. package/src/styles/theme.styl +25 -0
  155. package/test/__mocks__/fileMock.js +3 -0
  156. package/test/__snapshots__/index.spec.js.snap +41 -0
  157. package/test/components/AppItem.spec.jsx +113 -0
  158. package/test/components/AppsContent.spec.jsx +116 -0
  159. package/test/components/Settings/helper.spec.js +23 -0
  160. package/test/components/__snapshots__/AppsContent.spec.jsx.snap +90 -0
  161. package/test/index.spec.js +24 -0
  162. package/test/jestLib/I18n.js +15 -0
  163. package/test/jestLib/setup.js +14 -0
  164. package/test/lib/__snapshots__/api.spec.jsx.snap +67 -0
  165. package/test/lib/__snapshots__/stack.spec.js.snap +3 -0
  166. package/test/lib/api.spec.jsx +142 -0
  167. package/test/lib/mockStackClient.js +7 -0
  168. package/test/lib/stack-client/stack-client.appiconprops.spec.js +65 -0
  169. package/test/lib/stack-client/stack-client.compare.spec.js +20 -0
  170. package/test/lib/stack-client/stack-client.cozyfetchjson.spec.js +46 -0
  171. package/test/lib/stack-client/stack-client.cozyurl.spec.js +29 -0
  172. package/test/lib/stack-client/stack-client.getapp.spec.js +72 -0
  173. package/test/lib/stack-client/stack-client.getapps.spec.js +72 -0
  174. package/test/lib/stack-client/stack-client.getcontext.spec.js +96 -0
  175. package/test/lib/stack-client/stack-client.getstoragedata.spec.js +85 -0
  176. package/test/lib/stack-client/stack-client.init.spec.js +56 -0
  177. package/test/lib/stack-client/stack-client.intents.spec.js +27 -0
  178. package/test/lib/stack-client/stack-client.logout.spec.js +40 -0
  179. package/test/lib/stack.spec.js +60 -0
  180. package/test/store/__snapshots__/index.spec.js.snap +14 -0
  181. package/test/store/index.spec.js +41 -0
@@ -0,0 +1,145 @@
1
+ import React from 'react'
2
+ import PropTypes from 'prop-types'
3
+
4
+ import { translate } from 'cozy-ui/react/I18n'
5
+ import { Button, ButtonLink } from 'cozy-ui/react/Button'
6
+ import { isMobileApp } from 'cozy-device-helper'
7
+ import StorageData from 'components/Settings/StorageData'
8
+
9
+ const SettingsContent = ({
10
+ t,
11
+ onLogOut,
12
+ settingsAppURL,
13
+ storageData,
14
+ onClaudy,
15
+ isDrawer = false,
16
+ isClaudyLoading,
17
+ toggleSupport,
18
+ shoulDisplayViewOfferButton,
19
+ managerUrlPremiumLink,
20
+ viewOfferButtonText
21
+ }) => (
22
+ <div className="coz-nav-pop-content">
23
+ {isDrawer && <hr />}
24
+ {settingsAppURL && (
25
+ <ul className="coz-nav-group">
26
+ <li className="coz-nav-settings-item">
27
+ <a
28
+ role="menuitem"
29
+ href={`${settingsAppURL}#/profile`}
30
+ target="_self"
31
+ data-icon="icon-profile"
32
+ title={t('profile')}
33
+ >
34
+ <p className="coz-label">{t('profile')}</p>
35
+ </a>
36
+ </li>
37
+ <li className="coz-nav-settings-item">
38
+ <a
39
+ role="menuitem"
40
+ href={`${settingsAppURL}#/connectedDevices`}
41
+ target="_self"
42
+ data-icon="icon-connectedDevices"
43
+ title={t('connectedDevices')}
44
+ >
45
+ <p className="coz-label">{t('connectedDevices')}</p>
46
+ </a>
47
+ </li>
48
+ </ul>
49
+ )}
50
+ {isDrawer && onClaudy && !isMobileApp() && (
51
+ <ul className="coz-nav-group">
52
+ <li className="coz-nav-settings-item">
53
+ <Button
54
+ type="button"
55
+ role="menuitem"
56
+ className="coz-nav-settings-item-btn"
57
+ icon="cloud"
58
+ busy={isClaudyLoading}
59
+ onClick={onClaudy}
60
+ title={t('claudy.title')}
61
+ label={t('claudy.title')}
62
+ />
63
+ </li>
64
+ </ul>
65
+ )}
66
+ {!isDrawer && storageData && (
67
+ <ul className="coz-nav-group">
68
+ <li className="coz-nav-settings-item">
69
+ <a
70
+ role="menuitem"
71
+ data-icon="icon-storage"
72
+ target="_self"
73
+ title={t('storage')}
74
+ href={`${settingsAppURL}#/storage`}
75
+ >
76
+ {t('storage')}
77
+ <StorageData data={storageData} />
78
+ </a>
79
+ </li>
80
+ </ul>
81
+ )}
82
+ {(!isDrawer || !isMobileApp()) && shoulDisplayViewOfferButton && (
83
+ <ul className="coz-nav-group">
84
+ <li className="coz-nav-settings-item">
85
+ <ButtonLink
86
+ subtle
87
+ role="menuitem"
88
+ className="coz-nav-settings-item-btn"
89
+ icon="cloud-happy"
90
+ title={viewOfferButtonText}
91
+ label={viewOfferButtonText}
92
+ href={managerUrlPremiumLink}
93
+ />
94
+ </li>
95
+ </ul>
96
+ )}
97
+
98
+ {!isMobileApp() && (
99
+ <ul className="coz-nav-group">
100
+ <li className="coz-nav-settings-item">
101
+ <Button
102
+ type="button"
103
+ role="menuitem"
104
+ className="coz-nav-settings-item-btn"
105
+ onClick={toggleSupport}
106
+ icon="help"
107
+ title={t('help')}
108
+ label={t('help')}
109
+ />
110
+ </li>
111
+ </ul>
112
+ )}
113
+ <ul className="coz-nav-group">
114
+ <li className="coz-nav-settings-item">
115
+ <button
116
+ type="button"
117
+ role="menuitem"
118
+ data-icon="icon-logout"
119
+ onClick={onLogOut}
120
+ title={t('logout')}
121
+ >
122
+ {t('logout')}
123
+ </button>
124
+ </li>
125
+ </ul>
126
+ </div>
127
+ )
128
+
129
+ SettingsContent.defaultProps = {
130
+ shoulDisplayViewOfferButton: false
131
+ }
132
+
133
+ SettingsContent.propTypes = {
134
+ shoulDisplayViewOfferButton: PropTypes.bool,
135
+ t: PropTypes.func.isRequired,
136
+ onLogOut: PropTypes.func.isRequired,
137
+ settingsAppURL: PropTypes.string,
138
+ storageData: PropTypes.object,
139
+ onClaudy: PropTypes.oneOfType([PropTypes.bool, PropTypes.func]),
140
+ isDrawer: PropTypes.bool,
141
+ isClaudyLoading: PropTypes.bool,
142
+ toggleSupport: PropTypes.func.isRequired,
143
+ viewOfferButtonText: PropTypes.string
144
+ }
145
+ export default translate()(SettingsContent)
@@ -0,0 +1,29 @@
1
+ import React from 'react'
2
+ import { translate } from 'cozy-ui/react/I18n'
3
+
4
+ const StorageData = ({ t, data }) => {
5
+ const diskQuota = Number.isInteger(data.quota)
6
+ ? (data.quota / (1000 * 1000 * 1000)).toFixed(2)
7
+ : data.quota
8
+ const diskUsage = Number.isInteger(data.usage)
9
+ ? (data.usage / (1000 * 1000 * 1000)).toFixed(2)
10
+ : data.usage
11
+ return (
12
+ <div className="coz-nav-storage">
13
+ <p className="coz-nav-storage-text">
14
+ {t('storage_phrase', {
15
+ diskUsage,
16
+ diskQuota
17
+ })}
18
+ </p>
19
+ <progress
20
+ className="cozy-nav-storage-bar"
21
+ value={diskUsage}
22
+ max={diskQuota}
23
+ min="0"
24
+ />
25
+ </div>
26
+ )
27
+ }
28
+
29
+ export default translate()(StorageData)
@@ -0,0 +1,8 @@
1
+ import { compareClientVersion } from 'lib/stack-client'
2
+ export const isFetchingQueries = requests => {
3
+ return requests.some(request => request.fetchStatus === 'loading')
4
+ }
5
+
6
+ export const cozyClientCanCheckPremium = () => {
7
+ return compareClientVersion('8.3.0')
8
+ }
@@ -0,0 +1,218 @@
1
+ import React, { Component } from 'react'
2
+ import { connect } from 'react-redux'
3
+ import { compose } from 'redux'
4
+ import get from 'lodash/get'
5
+
6
+ import { translate } from 'cozy-ui/react/I18n'
7
+ import { Button } from 'cozy-ui/react/Button'
8
+ import { queryConnect } from 'cozy-client/dist'
9
+ import { models } from 'cozy-client'
10
+ let instanceModel = undefined
11
+ let hasAnOffer = undefined
12
+ let isFremiumFixed = undefined
13
+ if (models) {
14
+ instanceModel = models.instance
15
+ //TODO fallback from cozy-client
16
+ isFremiumFixed = data => {
17
+ const GB = 1000 * 1000 * 1000
18
+ const PREMIUM_QUOTA = 50 * GB
19
+ const quota = get(data, 'diskUsage.data.attributes.quota', false)
20
+ return parseInt(quota) < PREMIUM_QUOTA
21
+ }
22
+ hasAnOffer = data => {
23
+ return (
24
+ !instanceModel.isSelfHosted(data) &&
25
+ instanceModel.arePremiumLinksEnabled(data) &&
26
+ instanceModel.getUuid(data) &&
27
+ !isFremiumFixed(data)
28
+ )
29
+ }
30
+ }
31
+
32
+ import SettingsContent from 'components/Settings/SettingsContent'
33
+ import {
34
+ fetchSettingsData,
35
+ getStorageData,
36
+ getSettingsAppURL,
37
+ isSettingsBusy,
38
+ isFetchingSettings,
39
+ logOut
40
+ } from 'lib/reducers'
41
+
42
+ import { instanceReq, contextReq, diskUsageReq } from '../../queries'
43
+
44
+ import {
45
+ isFetchingQueries,
46
+ cozyClientCanCheckPremium
47
+ } from 'components/Settings/helper'
48
+
49
+ export class Settings extends Component {
50
+ constructor(props) {
51
+ super(props)
52
+ this.state = {
53
+ opened: false
54
+ }
55
+ }
56
+
57
+ componentDidMount() {
58
+ document.body.addEventListener('click', this.onClickOutside)
59
+ }
60
+
61
+ componentWillUnmount() {
62
+ document.body.removeEventListener('click', this.onClickOutside)
63
+ }
64
+
65
+ onClickOutside = event => {
66
+ if (this.props.isFetching || this.state.opened) {
67
+ // if it's not a cozy-bar nav popup, close the opened popup
68
+ if (!this.rootRef.contains(event.target)) {
69
+ this.setState({ opened: false })
70
+ event.stopPropagation()
71
+ }
72
+ }
73
+ }
74
+
75
+ toggleMenu = () => {
76
+ let stateUpdate = { opened: false }
77
+ // if popup already opened, stop here to close it
78
+ if (this.state.opened) return this.setState(stateUpdate)
79
+ // fetch data
80
+ this.props.fetchSettingsData()
81
+ this.setState({ opened: true })
82
+ }
83
+
84
+ render() {
85
+ const {
86
+ isBusy,
87
+ logOut,
88
+ onLogOut,
89
+ t,
90
+ toggleSupport,
91
+ diskUsageQuery,
92
+ instanceQuery,
93
+ contextQuery,
94
+ storageData,
95
+ settingsAppURL,
96
+ isFetching
97
+ } = this.props
98
+
99
+ let shouldDisplayViewOfferButton = false
100
+ let managerUrlPremiumLink
101
+ let isFetchingFromQueries
102
+ let viewOfferButtonText = ''
103
+ const canCheckPremium = cozyClientCanCheckPremium()
104
+ if (canCheckPremium) {
105
+ isFetchingFromQueries = isFetchingQueries([
106
+ diskUsageQuery,
107
+ instanceQuery,
108
+ contextQuery
109
+ ])
110
+ if (!isFetchingFromQueries) {
111
+ const data = {
112
+ context: contextQuery,
113
+ diskUsage: diskUsageQuery,
114
+ instance: instanceQuery
115
+ }
116
+ shouldDisplayViewOfferButton =
117
+ instanceModel.shouldDisplayOffers(data) || hasAnOffer(data)
118
+
119
+ if (shouldDisplayViewOfferButton && !hasAnOffer(data)) {
120
+ viewOfferButtonText = t('view_offers')
121
+ } else if (hasAnOffer(data)) {
122
+ viewOfferButtonText = t('view_my_offer')
123
+ }
124
+ managerUrlPremiumLink = instanceModel.buildPremiumLink(data)
125
+ }
126
+ }
127
+
128
+ let areAllFetchingDone = false
129
+ if (!canCheckPremium) {
130
+ areAllFetchingDone = !isFetching
131
+ } else {
132
+ areAllFetchingDone = !isFetchingFromQueries && !isFetching
133
+ }
134
+
135
+ const { opened } = this.state
136
+ const openMenu = opened && areAllFetchingDone
137
+ return (
138
+ <div
139
+ className="coz-nav coz-nav-settings"
140
+ ref={ref => {
141
+ this.rootRef = ref
142
+ }}
143
+ >
144
+ <Button
145
+ type="button"
146
+ theme="text"
147
+ onClick={this.toggleMenu}
148
+ className="coz-nav-settings-btn"
149
+ aria-controls="coz-nav-pop--settings"
150
+ busy={isBusy}
151
+ icon="gear"
152
+ label={t('menu.settings')}
153
+ />
154
+ <div
155
+ className="coz-nav-pop coz-nav-pop--settings"
156
+ id="coz-nav-pop--settings"
157
+ aria-hidden={!openMenu}
158
+ >
159
+ {areAllFetchingDone && (
160
+ <>
161
+ <SettingsContent
162
+ onLogOut={() => {
163
+ if (onLogOut && typeof onLogOut === 'function') {
164
+ onLogOut()
165
+ } else {
166
+ logOut()
167
+ }
168
+ }}
169
+ toggleSupport={toggleSupport}
170
+ storageData={storageData}
171
+ settingsAppURL={settingsAppURL}
172
+ shoulDisplayViewOfferButton={shouldDisplayViewOfferButton}
173
+ managerUrlPremiumLink={managerUrlPremiumLink}
174
+ viewOfferButtonText={viewOfferButtonText}
175
+ />
176
+ </>
177
+ )}
178
+ </div>
179
+ </div>
180
+ )
181
+ }
182
+ }
183
+
184
+ const mapStateToProps = state => ({
185
+ storageData: getStorageData(state),
186
+ settingsAppURL: getSettingsAppURL(state),
187
+ isBusy: isSettingsBusy(state),
188
+ isFetching: isFetchingSettings(state)
189
+ })
190
+
191
+ const mapDispatchToProps = dispatch => ({
192
+ fetchSettingsData: () => dispatch(fetchSettingsData()),
193
+ logOut: () => dispatch(logOut())
194
+ })
195
+ let exported
196
+ if (cozyClientCanCheckPremium()) {
197
+ exported = compose(
198
+ translate(),
199
+ queryConnect({
200
+ instanceQuery: instanceReq,
201
+ contextQuery: contextReq,
202
+ diskUsageQuery: diskUsageReq
203
+ }),
204
+ connect(
205
+ mapStateToProps,
206
+ mapDispatchToProps
207
+ )
208
+ )(Settings)
209
+ } else {
210
+ exported = compose(
211
+ translate(),
212
+ connect(
213
+ mapStateToProps,
214
+ mapDispatchToProps
215
+ )
216
+ )(Settings)
217
+ }
218
+ export default exported
@@ -0,0 +1,59 @@
1
+ import React, { Component } from 'react'
2
+ import Modal, { ModalContent } from 'cozy-ui/react/Modal'
3
+ import Spinner from 'cozy-ui/react/Spinner'
4
+ import { getIntents } from 'lib/stack'
5
+
6
+ class SupportModal extends Component {
7
+ constructor(props, context) {
8
+ super(props)
9
+ this.store = context.barStore
10
+ this.state = {
11
+ isLoading: false
12
+ }
13
+ this.intents = getIntents()
14
+ }
15
+
16
+ toggle = () => {
17
+ this.setState({ isLoading: true })
18
+ // init support intent
19
+ this.intents
20
+ .create('SUPPORT', 'io.cozy.settings')
21
+ .start(this.intentWrapperRef, () => {
22
+ this.setState({ isLoading: false })
23
+ })
24
+ }
25
+
26
+ componentDidMount() {
27
+ this.toggle()
28
+ }
29
+
30
+ render() {
31
+ const { isLoading } = this.state
32
+ return (
33
+ <div>
34
+ <Modal
35
+ secondaryAction={this.props.onClose}
36
+ className="coz-support-modal"
37
+ into="#cozy-bar-modal-dom-place"
38
+ closeBtnClassName="coz-support-modal-close"
39
+ >
40
+ <ModalContent className="coz-support-modal-wrapper u-mt-1">
41
+ <div className="coz-support-modal-content">
42
+ {isLoading && <Spinner size="xxlarge" middle />}
43
+ <div
44
+ className={`coz-support-intent-wrapper${
45
+ isLoading ? ' coz-hidden' : ''
46
+ }`}
47
+ ref={wrapper => {
48
+ this.intentWrapperRef = wrapper
49
+ }}
50
+ />
51
+ </div>
52
+ </ModalContent>
53
+ </Modal>
54
+ </div>
55
+ )
56
+ }
57
+ }
58
+
59
+ export default SupportModal