openstack-uicore-foundation 4.1.43 → 4.1.44

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 (187) hide show
  1. package/lib/components/ajaxloader.js +2 -184
  2. package/lib/components/ajaxloader.js.map +1 -0
  3. package/lib/components/attendance-tracker.js +2 -2066
  4. package/lib/components/attendance-tracker.js.map +1 -0
  5. package/lib/components/bulk-actions-selector.js +2 -197
  6. package/lib/components/bulk-actions-selector.js.map +1 -0
  7. package/lib/components/circle-button.js +2 -223
  8. package/lib/components/circle-button.js.map +1 -0
  9. package/lib/components/clock.js +2 -767
  10. package/lib/components/clock.js.map +1 -0
  11. package/lib/components/exclusive-wrapper.js +2 -151
  12. package/lib/components/exclusive-wrapper.js.map +1 -0
  13. package/lib/components/extra-questions.js +2 -2011
  14. package/lib/components/extra-questions.js.map +1 -0
  15. package/lib/components/form-validation.js +2 -190
  16. package/lib/components/form-validation.js.map +1 -0
  17. package/lib/components/forms/rsvp-form.js +2 -940
  18. package/lib/components/forms/rsvp-form.js.map +1 -0
  19. package/lib/components/forms/simple-form.js +2 -774
  20. package/lib/components/forms/simple-form.js.map +1 -0
  21. package/lib/components/free-text-search.js +2 -2154
  22. package/lib/components/free-text-search.js.map +1 -0
  23. package/lib/components/google-map.js +2 -642
  24. package/lib/components/google-map.js.map +1 -0
  25. package/lib/components/index.js +2 -13417
  26. package/lib/components/index.js.map +1 -0
  27. package/lib/components/inputs/access-levels-input.js +2 -2381
  28. package/lib/components/inputs/access-levels-input.js.map +1 -0
  29. package/lib/components/inputs/action-dropdown.js +2 -219
  30. package/lib/components/inputs/action-dropdown.js.map +1 -0
  31. package/lib/components/inputs/checkbox-list.js +2 -339
  32. package/lib/components/inputs/checkbox-list.js.map +1 -0
  33. package/lib/components/inputs/company-input.js +2 -2416
  34. package/lib/components/inputs/company-input.js.map +1 -0
  35. package/lib/components/inputs/country-dropdown.js +2 -2474
  36. package/lib/components/inputs/country-dropdown.js.map +1 -0
  37. package/lib/components/inputs/country-input.js +2 -2377
  38. package/lib/components/inputs/country-input.js.map +1 -0
  39. package/lib/components/inputs/datetimepicker.js +2 -314
  40. package/lib/components/inputs/datetimepicker.js.map +1 -0
  41. package/lib/components/inputs/dropdown.js +2 -259
  42. package/lib/components/inputs/dropdown.js.map +1 -0
  43. package/lib/components/inputs/editor-input.js +2 -270
  44. package/lib/components/inputs/editor-input.js.map +1 -0
  45. package/lib/components/inputs/event-input.js +2 -2355
  46. package/lib/components/inputs/event-input.js.map +1 -0
  47. package/lib/components/inputs/free-multi-text-input.js +2 -252
  48. package/lib/components/inputs/free-multi-text-input.js.map +1 -0
  49. package/lib/components/inputs/group-input.js +2 -2350
  50. package/lib/components/inputs/group-input.js.map +1 -0
  51. package/lib/components/inputs/grouped-dropdown.js +2 -244
  52. package/lib/components/inputs/grouped-dropdown.js.map +1 -0
  53. package/lib/components/inputs/language-input.js +2 -2382
  54. package/lib/components/inputs/language-input.js.map +1 -0
  55. package/lib/components/inputs/member-input.js +2 -2377
  56. package/lib/components/inputs/member-input.js.map +1 -0
  57. package/lib/components/inputs/operator-input.js +2 -328
  58. package/lib/components/inputs/operator-input.js.map +1 -0
  59. package/lib/components/inputs/organization-input.js +2 -2400
  60. package/lib/components/inputs/organization-input.js.map +1 -0
  61. package/lib/components/inputs/promocode-input.js +2 -2385
  62. package/lib/components/inputs/promocode-input.js.map +1 -0
  63. package/lib/components/inputs/radio-list.js +2 -297
  64. package/lib/components/inputs/radio-list.js.map +1 -0
  65. package/lib/components/inputs/registration-company-input.js +2 -2438
  66. package/lib/components/inputs/registration-company-input.js.map +1 -0
  67. package/lib/components/inputs/speaker-input.js +2 -2411
  68. package/lib/components/inputs/speaker-input.js.map +1 -0
  69. package/lib/components/inputs/sponsor-input.js +2 -2359
  70. package/lib/components/inputs/sponsor-input.js.map +1 -0
  71. package/lib/components/inputs/stepped-select.js +2 -197
  72. package/lib/components/inputs/stepped-select.js.map +1 -0
  73. package/lib/components/inputs/summit-days-select.js +2 -162
  74. package/lib/components/inputs/summit-days-select.js.map +1 -0
  75. package/lib/components/inputs/summit-input.js +2 -2357
  76. package/lib/components/inputs/summit-input.js.map +1 -0
  77. package/lib/components/inputs/summit-venues-select.js +2 -203
  78. package/lib/components/inputs/summit-venues-select.js.map +1 -0
  79. package/lib/components/inputs/tag-input.js +2 -2427
  80. package/lib/components/inputs/tag-input.js.map +1 -0
  81. package/lib/components/inputs/text-input.js +2 -202
  82. package/lib/components/inputs/text-input.js.map +1 -0
  83. package/lib/components/inputs/textarea-input.js +2 -174
  84. package/lib/components/inputs/textarea-input.js.map +1 -0
  85. package/lib/components/inputs/ticket-types-input.js +2 -2415
  86. package/lib/components/inputs/ticket-types-input.js.map +1 -0
  87. package/lib/components/inputs/upload-input-v2.js +2 -860
  88. package/lib/components/inputs/upload-input-v2.js.map +1 -0
  89. package/lib/components/inputs/upload-input.js +2 -391
  90. package/lib/components/inputs/upload-input.js.map +1 -0
  91. package/lib/components/progressive-img.js +2 -296
  92. package/lib/components/progressive-img.js.map +1 -0
  93. package/lib/components/raw-html.js +2 -125
  94. package/lib/components/raw-html.js.map +1 -0
  95. package/lib/components/schedule-builder-constants.js +2 -87
  96. package/lib/components/schedule-builder-constants.js.map +1 -0
  97. package/lib/components/schedule-builder-view.js +2 -2188
  98. package/lib/components/schedule-builder-view.js.map +1 -0
  99. package/lib/components/sections/panel.js +2 -156
  100. package/lib/components/sections/panel.js.map +1 -0
  101. package/lib/components/simple-link-list.js +2 -790
  102. package/lib/components/simple-link-list.js.map +1 -0
  103. package/lib/components/sponsored-project-input.js +2 -2356
  104. package/lib/components/sponsored-project-input.js.map +1 -0
  105. package/lib/components/summit-dropdown.js +2 -214
  106. package/lib/components/summit-dropdown.js.map +1 -0
  107. package/lib/components/table-editable.js +2 -961
  108. package/lib/components/table-editable.js.map +1 -0
  109. package/lib/components/table-selectable.js +2 -552
  110. package/lib/components/table-selectable.js.map +1 -0
  111. package/lib/components/table-sortable.js +2 -743
  112. package/lib/components/table-sortable.js.map +1 -0
  113. package/lib/components/table.js +2 -510
  114. package/lib/components/table.js.map +1 -0
  115. package/lib/components/video-stream.js +2 -226
  116. package/lib/components/video-stream.js.map +1 -0
  117. package/lib/css/components/bulk-actions-selector.css +2 -19
  118. package/lib/css/components/bulk-actions-selector.css.map +1 -0
  119. package/lib/css/components/circle-button.css +1 -28
  120. package/lib/css/components/extra-questions.css +2 -35
  121. package/lib/css/components/extra-questions.css.map +1 -0
  122. package/lib/css/components/form-validation.css +2 -29
  123. package/lib/css/components/form-validation.css.map +1 -0
  124. package/lib/css/components/free-text-search.css +2 -35
  125. package/lib/css/components/free-text-search.css.map +1 -0
  126. package/lib/css/components/index.css +3 -1398
  127. package/lib/css/components/index.css.map +1 -0
  128. package/lib/css/components/inputs/action-dropdown.css +2 -46
  129. package/lib/css/components/inputs/action-dropdown.css.map +1 -0
  130. package/lib/css/components/inputs/datetimepicker.css +2 -208
  131. package/lib/css/components/inputs/datetimepicker.css.map +1 -0
  132. package/lib/css/components/inputs/grouped-dropdown.css +2 -25
  133. package/lib/css/components/inputs/grouped-dropdown.css.map +1 -0
  134. package/lib/css/components/inputs/stepped-select.css +2 -12
  135. package/lib/css/components/inputs/stepped-select.css.map +1 -0
  136. package/lib/css/components/inputs/upload-input-v2.css +2 -108
  137. package/lib/css/components/inputs/upload-input-v2.css.map +1 -0
  138. package/lib/css/components/inputs/upload-input.css +2 -43
  139. package/lib/css/components/inputs/upload-input.css.map +1 -0
  140. package/lib/css/components/progressive-img.css +1 -18
  141. package/lib/css/components/schedule-builder-view.css +2 -249
  142. package/lib/css/components/schedule-builder-view.css.map +1 -0
  143. package/lib/css/components/simple-link-list.css +2 -195
  144. package/lib/css/components/simple-link-list.css.map +1 -0
  145. package/lib/css/components/summit-dropdown.css +2 -35
  146. package/lib/css/components/summit-dropdown.css.map +1 -0
  147. package/lib/css/components/table-editable.css +2 -145
  148. package/lib/css/components/table-editable.css.map +1 -0
  149. package/lib/css/components/table-selectable.css +2 -147
  150. package/lib/css/components/table-selectable.css.map +1 -0
  151. package/lib/css/components/table-sortable.css +2 -156
  152. package/lib/css/components/table-sortable.css.map +1 -0
  153. package/lib/css/components/table.css +2 -147
  154. package/lib/css/components/table.css.map +1 -0
  155. package/lib/i18n.js +2 -515
  156. package/lib/i18n.js.map +1 -0
  157. package/lib/models/index.js +2 -238
  158. package/lib/models/index.js.map +1 -0
  159. package/lib/models/summit-event.js +2 -210
  160. package/lib/models/summit-event.js.map +1 -0
  161. package/lib/security/abstract-auth-callback-route.js +2 -2192
  162. package/lib/security/abstract-auth-callback-route.js.map +1 -0
  163. package/lib/security/actions.js +2 -1892
  164. package/lib/security/actions.js.map +1 -0
  165. package/lib/security/constants.js +2 -75
  166. package/lib/security/constants.js.map +1 -0
  167. package/lib/security/methods.js +2 -1892
  168. package/lib/security/methods.js.map +1 -0
  169. package/lib/security/reducers.js +2 -2035
  170. package/lib/security/reducers.js.map +1 -0
  171. package/lib/security/session-checker.js +2 -2253
  172. package/lib/security/session-checker.js.map +1 -0
  173. package/lib/utils/actions.js +2 -1892
  174. package/lib/utils/actions.js.map +1 -0
  175. package/lib/utils/fragment-parser.js +2 -207
  176. package/lib/utils/fragment-parser.js.map +1 -0
  177. package/lib/utils/methods.js +2 -435
  178. package/lib/utils/methods.js.map +1 -0
  179. package/lib/utils/query-actions.js +2 -2229
  180. package/lib/utils/query-actions.js.map +1 -0
  181. package/lib/utils/questions-set.js +2 -681
  182. package/lib/utils/questions-set.js.map +1 -0
  183. package/lib/utils/reducers.js +2 -1948
  184. package/lib/utils/reducers.js.map +1 -0
  185. package/lib/utils/use-fit-text.js +2 -178
  186. package/lib/utils/use-fit-text.js.map +1 -0
  187. package/package.json +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils/reducers.js","mappings":"CAAA,SAA2CA,EAAMC,GAC1B,iBAAZC,SAA0C,iBAAXC,OACxCA,OAAOD,QAAUD,IACQ,mBAAXG,QAAyBA,OAAOC,IAC9CD,OAAO,8BAA+B,GAAIH,GAChB,iBAAZC,QACdA,QAAQ,+BAAiCD,IAEzCD,EAAK,+BAAiCC,GACvC,CATD,CASGK,MAAM,I,iHCTT,MAAM,EAA+BC,QAAQ,qB,qCCARA,QAAQ,oBCARA,QAAQ,2BCARA,QAAQ,qBCMZ,oBAAXC,SAA0BA,OAAOC,QAAUD,OAAOE,UCc3D,IAAIC,I,mJCEV,MAGMC,EAAiB,eAEjBC,EAAiB,gBACjBC,EAAiB,eAEjBC,EAAeC,GAAQC,IAAW,CAC3CD,OACAC,YAGwBF,EAZE,iBAaFA,EAZE,iBAaFA,EAAaH,E,2CCrCzCT,EAAOD,QAAUK,QAAQ,wC,WCAzBJ,EAAOD,QAAUK,QAAQ,iD,WCAzBJ,EAAOD,QAAUK,QAAQ,6B,WCAzBJ,EAAOD,QAAUK,QAAQ,mB,WCAzBJ,EAAOD,QAAUK,QAAQ,kB,WCAzBJ,EAAOD,QAAUK,QAAQ,wB,UCAzBJ,EAAOD,QAAUK,QAAQ,c,WCAzBJ,EAAOD,QAAUK,QAAQ,Q,GCCrBW,EAA2B,CAAC,EAGhC,SAASC,EAAoBC,GAE5B,IAAIC,EAAeH,EAAyBE,GAC5C,QAAqBE,IAAjBD,EACH,OAAOA,EAAanB,QAGrB,IAAIC,EAASe,EAAyBE,GAAY,CAGjDlB,QAAS,CAAC,GAOX,OAHAqB,EAAoBH,GAAUjB,EAAQA,EAAOD,QAASiB,GAG/ChB,EAAOD,OACf,C,MCrBAiB,EAAoBK,EAAKrB,IACxB,IAAIsB,EAAStB,GAAUA,EAAOuB,WAC7B,IAAOvB,EAAiB,QACxB,IAAM,EAEP,OADAgB,EAAoBQ,EAAEF,EAAQ,CAAEG,EAAGH,IAC5BA,CAAM,C,WCLdN,EAAoBQ,EAAI,CAACzB,EAAS2B,KACjC,IAAI,IAAIC,KAAOD,EACXV,EAAoBY,EAAEF,EAAYC,KAASX,EAAoBY,EAAE7B,EAAS4B,IAC5EE,OAAOC,eAAe/B,EAAS4B,EAAK,CAAEI,YAAY,EAAMC,IAAKN,EAAWC,IAE1E,C,WCNDX,EAAoBY,EAAI,CAACK,EAAKC,IAAUL,OAAOM,UAAUC,eAAeC,KAAKJ,EAAKC,E,WCClFlB,EAAoBsB,EAAKvC,IACH,oBAAXwC,QAA0BA,OAAOC,aAC1CX,OAAOC,eAAe/B,EAASwC,OAAOC,YAAa,CAAEC,MAAO,WAE7DZ,OAAOC,eAAe/B,EAAS,aAAc,CAAE0C,OAAO,GAAO,C,kqBCc9D,MAAMC,EAAgB,CAClBC,IAAK,KACLC,SAAU,KACVC,OAAQ,CAAC,EACTC,SAAS,GAGAC,EAAmB,SAAWC,EAAQN,EAAeO,EAAS,CAAC,GACxE,OAAOA,EAAOpC,MACV,KAAKF,EAAAA,aACD,OAAO,EAAP,KACOqC,GADP,IAEIL,IAAKM,EAAOnC,QAAQ6B,IACpBC,SAAUK,EAAOnC,QAAQ8B,WAGjC,KAAKlC,EAAAA,cACD,OAAO,EAAP,KAAYsC,GAAZ,IAAmBL,IAAK,OAE5B,KAAKlC,EAAAA,aACD,OAAO,EAAP,KAAYuC,GAAZ,IAAmBF,SAAS,IAEhC,QACI,OAAOE,EAElB,C","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/external commonjs \"browser-tabs-lock\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/sha256\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-base64url\"","webpack://openstack-uicore-foundation/external commonjs \"crypto-js/enc-hex\"","webpack://openstack-uicore-foundation/./src/utils/crypto.js","webpack://openstack-uicore-foundation/./src/components/security/methods.js","webpack://openstack-uicore-foundation/./src/utils/actions.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"idtoken-verifier\"","webpack://openstack-uicore-foundation/external commonjs \"moment-timezone\"","webpack://openstack-uicore-foundation/external commonjs \"superagent/lib/client\"","webpack://openstack-uicore-foundation/external commonjs \"sweetalert2\"","webpack://openstack-uicore-foundation/external commonjs \"urijs\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/utils/reducers.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"browser-tabs-lock\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/sha256\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-base64url\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js/enc-hex\");","// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nconst MAX_BYTES = 65536\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nconst MAX_UINT32 = 4294967295\nconst crypto = typeof window !== 'undefined' ? (window.crypto || window.msCrypto) : null;\nimport sha256 from 'crypto-js/sha256';\nimport Base64url from 'crypto-js/enc-base64url'\nimport Hex from 'crypto-js/enc-hex'\nexport const getRandomBytes = (size) => {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes')\n const bytes = Buffer.allocUnsafe(size)\n if(!crypto) return a;\n if (size > 0) { // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) { // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (let generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES))\n }\n } else {\n crypto.getRandomValues(bytes)\n }\n }\n return bytes\n}\n\nexport const getSHA256 = (message, format = 'hex') => {\n\n let f = Hex;\n if(format === 'Base64url')\n f = Base64url;\n\n return sha256(message).toString(f);\n}","import {\n base64URLEncode,\n getAuthCallback,\n getCurrentLocation,\n getCurrentPathName,\n getFromLocalStorage,\n removeFromLocalStorage,\n getOrigin,\n putOnLocalStorage,\n retryPromise,\n setSessionClearingState,\n} from \"../../utils/methods\";\nimport request from 'superagent/lib/client';\nimport SuperTokensLock from 'browser-tabs-lock';\n\nlet http = request;\n\n/**\n * @ignore\n */\nconst Lock = new SuperTokensLock();\n\nconst GET_TOKEN_SILENTLY_LOCK_KEY = 'openstackuicore.lock.getTokenSilently';\nconst GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT = 6000;\nconst NONCE_LEN = 16;\nexport const ACCESS_TOKEN_SKEW_TIME = 20;\nexport const RESPONSE_TYPE_IMPLICIT = \"token id_token\";\nexport const RESPONSE_TYPE_CODE = 'code';\nconst AUTH_INFO = 'authInfo';\nconst NONCE = 'nonce';\nconst PKCE = 'pkce';\n\nimport URI from \"urijs\";\nimport IdTokenVerifier from \"idtoken-verifier\";\nimport {SET_LOGGED_USER} from \"./actions\";\nimport {getRandomBytes, getSHA256} from \"../../utils/crypto\";\n\nimport {\n AUTH_ERROR_ACCESS_TOKEN_EXPIRED,\n AUTH_ERROR_MISSING_AUTH_INFO,\n AUTH_ERROR_MISSING_REFRESH_TOKEN,\n AUTH_ERROR_LOCK_ACQUIRE_ERROR,\n AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR,\n AUTH_ERROR_ID_TOKEN_INVALID,\n AUTH_ERROR_MISSING_OTP_PARAM,\n AUTH_ERROR_MISSING_PKCE_PARAM,\n AUTH_ERROR_MISSING_NONCE_PARAM,\n} from \"./constants\";\n\n/**\n *\n * @param backUrl\n * @param prompt\n * @param tokenIdHint\n * @param provider\n * @param loginHint\n * @param otpLoginHint\n * @returns {*}\n */\nexport const getAuthUrl = (\n backUrl = null,\n prompt = null,\n tokenIdHint = null,\n provider = null,\n loginHint = null,\n otpLoginHint = null) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let baseUrl = getOAuth2IDPBaseUrl();\n let scopes = getOAuth2Scopes();\n let flow = getOAuth2Flow();\n\n if (backUrl != null)\n redirectUri += `?BackUrl=${encodeURI(backUrl)}`;\n\n let nonce = createNonce(NONCE_LEN);\n\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let query = {\n \"response_type\": encodeURI(flow),\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"response_mode\": 'fragment',\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n if (flow === RESPONSE_TYPE_CODE) {\n const pkce = createPKCECodes()\n putOnLocalStorage(PKCE, JSON.stringify(pkce));\n query['code_challenge'] = pkce.codeChallenge;\n query['code_challenge_method'] = 'S256';\n query['approval_prompt'] = 'force';\n }\n\n if (prompt) {\n query['prompt'] = prompt;\n }\n\n if (scopes && scopes.includes('offline_access')) {\n // then we need to force prompt=consent bc we are requesting an offline access\n // and we need to let the user know\n query['prompt'] = 'consent';\n }\n\n if (tokenIdHint) {\n query['id_token_hint'] = tokenIdHint;\n }\n\n if (provider) {\n query['provider'] = provider;\n }\n\n if (otpLoginHint) {\n query['otp_login_hint'] = otpLoginHint;\n }\n\n if (loginHint) {\n query['login_hint'] = encodeURI(loginHint);\n }\n\n url = url.query(query);\n //console.log(`getAuthUrl ${url.toString()}`);\n return url;\n}\n\nexport const getLogoutUrl = (idToken) => {\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let url = URI(`${baseUrl}/oauth2/end-session`);\n let state = createNonce(NONCE_LEN);\n let postLogOutUri = getOrigin() + '/auth/logout';\n // store nonce to check it later\n putOnLocalStorage('post_logout_state', state);\n /**\n * post_logout_redirect_uri should be listed on oauth2 client settings\n * on IDP\n * \"Security Settings\" Tab -> Logout Options -> Post Logout Uris\n */\n return url.query({\n \"id_token_hint\": idToken,\n \"post_logout_redirect_uri\": encodeURI(postLogOutUri),\n \"client_id\": encodeURI(oauth2ClientId),\n \"state\": state,\n });\n}\n\nconst createNonce = (len) => {\n let possible = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\n let nonce = '';\n for (let i = 0; i < len; i++) {\n nonce += possible.charAt(Math.floor(Math.random() * possible.length));\n }\n return nonce;\n}\n\n/**\n *\n * @param backUrl\n * @param provider\n * @param prompt\n * @param loginHint\n * @param otpLoginHint\n */\nexport const doLogin = (\n backUrl = null,\n provider = null,\n prompt = null,\n loginHint = null,\n otpLoginHint = null\n) => {\n let url = getAuthUrl(backUrl, prompt, null, provider, loginHint, otpLoginHint);\n let location = getCurrentLocation()\n location.replace(url.toString());\n}\n\n/**\n *\n * @param backUrl\n * @param loginHint\n * @param otpLoginHint\n */\nexport const doLoginBasicLogin = (backUrl = null, loginHint = null, otpLoginHint = null) => {\n doLogin(backUrl, null, null, loginHint, otpLoginHint);\n}\n\nconst createPKCECodes = () => {\n const codeVerifier = base64URLEncode(getRandomBytes(64))\n const codeChallenge = getSHA256(codeVerifier, 'Base64url')\n const createdAt = new Date()\n const codePair = {\n codeVerifier,\n codeChallenge,\n createdAt\n }\n return codePair\n}\n\nexport const emitAccessToken = async (code, backUrl = null) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n let redirectUri = getAuthCallback();\n let pkce = JSON.parse(getFromLocalStorage(PKCE, true));\n\n if(!pkce)\n throw Error(AUTH_ERROR_MISSING_PKCE_PARAM);\n\n if (backUrl != null)\n redirectUri += `?BackUrl=${encodeURI(backUrl)}`;\n\n const payload = {\n 'code': code,\n 'grant_type': 'authorization_code',\n 'code_verifier': pkce.codeVerifier,\n \"client_id\": encodeURI(oauth2ClientId),\n \"redirect_uri\": encodeURI(redirectUri)\n };\n\n try {\n //const response = await http.post(`${baseUrl}/oauth2/token`, payload);\n //const {body: {access_token, refresh_token, id_token, expires_in}} = response;\n const response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload)\n }).catch(function (error) {\n console.log('Request failed:', error.message);\n });\n const json = await response.json();\n let {access_token, refresh_token, id_token, expires_in, error, error_description} = json;\n return {access_token, refresh_token, id_token, expires_in, error, error_description}\n } catch (err) {\n console.log(err);\n }\n};\n\nexport const clearAccessToken = async () => {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n\n storeAuthInfo(null, 0, refreshToken)\n\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n }\n}\n\nconst processRefreshToken = async (flow, refreshToken) => {\n\n if (flow === RESPONSE_TYPE_CODE && useOAuth2RefreshToken()) {\n //console.log('getAccessToken getting new access token, access token got void');\n if (!refreshToken) {\n clearAuthInfo();\n throw Error(AUTH_ERROR_MISSING_REFRESH_TOKEN);\n }\n\n let response = await refreshAccessToken(refreshToken);\n let {access_token, expires_in, refresh_token} = response;\n //console.log(`getAccessToken access_token ${access_token} expires_in ${expires_in} refresh_token ${refresh_token}`);\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n storeAuthInfo(access_token, expires_in, refresh_token);\n //console.log(`getAccessToken access_token ${access_token} [NEW]`);\n return access_token;\n }\n clearAuthInfo();\n throw Error(AUTH_ERROR_ACCESS_TOKEN_EXPIRED);\n}\n\nexport const getAccessToken = async () => {\n if (\n await retryPromise(\n () => Lock.acquireLock(GET_TOKEN_SILENTLY_LOCK_KEY, GET_TOKEN_SILENTLY_LOCK_KEY_TIMEOUT),\n 10\n )\n ) {\n try {\n let authInfo = getAuthInfo();\n\n if (!authInfo) {\n throw Error(AUTH_ERROR_MISSING_AUTH_INFO);\n }\n\n let {accessToken, expiresIn, accessTokenUpdatedAt, refreshToken} = authInfo;\n let flow = getOAuth2Flow();\n // check life time\n let now = Math.floor(Date.now() / 1000);\n let timeElapsedSecs = (now - accessTokenUpdatedAt);\n expiresIn = (expiresIn - ACCESS_TOKEN_SKEW_TIME);\n\n if (timeElapsedSecs > expiresIn || accessToken == null) {\n console.log(`getAccessToken access token expired`)\n return processRefreshToken(flow, refreshToken);\n }\n return accessToken;\n } finally {\n await Lock.releaseLock(GET_TOKEN_SILENTLY_LOCK_KEY);\n }\n }\n // error on locking\n throw Error(AUTH_ERROR_LOCK_ACQUIRE_ERROR);\n}\n\nexport const refreshAccessToken = async (refresh_token) => {\n\n let baseUrl = getOAuth2IDPBaseUrl();\n let oauth2ClientId = getOAuth2ClientId();\n\n const payload = {\n 'grant_type': 'refresh_token',\n \"client_id\": encodeURI(oauth2ClientId),\n \"refresh_token\": refresh_token\n };\n\n try {\n const response = await fetch(`${baseUrl}/oauth2/token`, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(payload)\n }).then((response) => {\n if (response.status === 400) {\n let currentLocation = getCurrentPathName();\n setSessionClearingState(true);\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: ${response.status} - ${response.statusText}`);\n }\n return response;\n\n }).catch(function (error) {\n throw Error(`${AUTH_ERROR_REFRESH_TOKEN_REQUEST_ERROR}: ${error.message}`);\n });\n\n const json = await response.json();\n let {access_token, refresh_token, expires_in} = json;\n return {access_token, refresh_token, expires_in}\n } catch (err) {\n console.log(err);\n throw err;\n }\n}\n\nexport const storeAuthInfo = (accessToken, expiresIn, refreshToken = null, idToken = null) => {\n\n let formerAuthInfo = getAuthInfo();\n\n let authInfo = {\n accessToken: accessToken,\n expiresIn: expiresIn,\n accessTokenUpdatedAt: Math.floor(Date.now() / 1000),\n };\n\n if (refreshToken === null && formerAuthInfo) {\n refreshToken = formerAuthInfo.refreshToken;\n }\n\n if (idToken === null && formerAuthInfo) {\n idToken = formerAuthInfo.idToken;\n }\n\n if (refreshToken) {\n authInfo['refreshToken'] = refreshToken;\n }\n\n if (idToken) {\n authInfo['idToken'] = idToken;\n }\n\n putOnLocalStorage(AUTH_INFO, JSON.stringify(authInfo));\n}\n\nexport const getAuthInfo = () => {\n try {\n let res = getFromLocalStorage(AUTH_INFO, false)\n if (!res) return null;\n return JSON.parse(res);\n } catch (err) {\n return null;\n }\n}\n\nexport const clearAuthInfo = () => {\n if (typeof window !== 'undefined') {\n removeFromLocalStorage(AUTH_INFO);\n }\n};\n\nexport const getIdToken = () => {\n if (typeof window !== 'undefined') {\n const authInfo = getAuthInfo();\n if (authInfo) {\n return authInfo.idToken;\n }\n return null;\n }\n return null;\n};\n\nexport const getOAuth2ClientId = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_CLIENT_ID;\n }\n return null;\n};\n\nexport const getOAuth2Flow = () => {\n if (typeof window !== 'undefined') {\n return window.OAUTH2_FLOW || \"token id_token\";\n }\n return \"token id_token\";\n}\n\nexport const useOAuth2RefreshToken = () => {\n if (typeof window !== 'undefined') {\n return new Boolean(window.OAUTH2_USE_REFRESH_TOKEN || true);\n }\n return true;\n}\n\nexport const getOAuth2IDPBaseUrl = () => {\n if (typeof window !== 'undefined') {\n return window.IDP_BASE_URL;\n }\n return null;\n};\n\nexport const getOAuth2Scopes = () => {\n if (typeof window !== 'undefined') {\n return window.SCOPES;\n }\n return null;\n};\n\nexport const initLogOut = () => {\n let location = getCurrentLocation();\n location.replace(getLogoutUrl(getIdToken()).toString());\n}\n\nexport const validateIdToken = (idToken, issuer, audience) => {\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n let storedNonce = getFromLocalStorage(NONCE, true);\n if(!storedNonce)\n throw Error(AUTH_ERROR_MISSING_NONCE_PARAM);\n\n let jwt = verifier.decode(idToken);\n let alg = jwt.header.alg;\n let kid = jwt.header.kid;\n let aud = jwt.payload.aud;\n let iss = jwt.payload.iss;\n let exp = jwt.payload.exp;\n let nbf = jwt.payload.nbf;\n let tnonce = jwt.payload.nonce || null;\n\n return tnonce == storedNonce && aud == audience && iss == issuer;\n}\n\nexport const passwordlessStart = (params) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let nonce = createNonce(NONCE_LEN);\n // store nonce to check it later\n putOnLocalStorage(NONCE, nonce);\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/auth`);\n\n let payload = {\n \"response_type\": \"otp\",\n \"scope\": encodeURI(scopes),\n \"nonce\": nonce,\n \"client_id\": encodeURI(oauth2ClientId),\n \"connection\": params.connection || \"email\",\n \"send\": params.send || \"code\",\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n if (params.hasOwnProperty('redirect_uri')) {\n payload[\"redirect_uri\"] = encodeURIComponent(params.redirect_uri);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n let json = res.body;\n return Promise.resolve({response: json});\n }).catch((err) => {\n return Promise.reject(err);\n });\n\n}\n\nexport const passwordlessLogin = (params) => (dispatch) => {\n\n let oauth2ClientId = getOAuth2ClientId();\n let scopes = getOAuth2Scopes();\n let baseUrl = getOAuth2IDPBaseUrl();\n let url = URI(`${baseUrl}/oauth2/token`);\n\n if (!params.hasOwnProperty(\"otp\")) {\n throw Error(AUTH_ERROR_MISSING_OTP_PARAM);\n }\n\n let payload = {\n \"grant_type\": \"passwordless\",\n \"connection\": params.connection || \"email\",\n \"scope\": encodeURI(scopes),\n \"client_id\": encodeURI(oauth2ClientId),\n \"otp\": params.otp\n };\n\n if (params.hasOwnProperty('email')) {\n payload[\"email\"] = encodeURIComponent(params.email);\n }\n\n if (params.hasOwnProperty('phone_number')) {\n payload[\"phone_number\"] = encodeURIComponent(params.phone_number);\n }\n\n let req = http.post(url.toString());\n\n return req.send(payload).then((res) => {\n try {\n // now we got token\n let json = res.body;\n let {access_token, expires_in, refresh_token, id_token} = json;\n\n if (typeof refresh_token === 'undefined') {\n refresh_token = null; // not using rotate policy\n }\n\n if (typeof id_token === 'undefined') {\n id_token = null; // not using rotate policy\n }\n\n // verify id token\n\n if (id_token) {\n if (!validateIdToken(id_token, baseUrl, oauth2ClientId)) {\n throw Error(AUTH_ERROR_ID_TOKEN_INVALID);\n }\n }\n\n storeAuthInfo(access_token, expires_in, refresh_token, id_token);\n\n if (dispatch) {\n dispatch({\n type: SET_LOGGED_USER,\n payload: {sessionState: null}\n });\n }\n\n return Promise.resolve({response: json});\n } catch (e) {\n console.log(e);\n return Promise.reject(e);\n }\n }).catch((err) => {\n return Promise.reject(err);\n });\n}\n\nexport const isIdTokenAlive = (nowEpoch = null) => () => {\n\n if (!nowEpoch) {\n nowEpoch = Math.floor(Date.now() / 1000);\n }\n\n const idToken = getIdToken();\n if (!idToken)\n throw Error('Id Token not set.');\n\n const issuer = getOAuth2IDPBaseUrl();\n const audience = getOAuth2ClientId();\n\n let verifier = new IdTokenVerifier({\n issuer: issuer,\n audience: audience\n });\n\n const jwt = verifier.decode(idToken);\n const exp = jwt.payload.exp;\n\n // check life time\n return exp - (nowEpoch + ACCESS_TOKEN_SKEW_TIME) > 0;\n}\n","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific flanguage governing permissions and\n * limitations under the License.\n **/\n\nimport request from 'superagent/lib/client';\nimport URI from \"urijs\";\nlet http = request;\nimport Swal from 'sweetalert2';\nimport T from \"i18n-react/dist/i18n-react\";\nimport { isClearingSessionState, setSessionClearingState, getCurrentPathName } from './methods';\nimport { CLEAR_SESSION_STATE } from '../components/security/actions';\nimport { doLogin, initLogOut } from '../components/security/methods';\n\nexport const GENERIC_ERROR = \"Yikes. Something seems to be broken. Our web team has been notified, and we apologize for the inconvenience.\";\nexport const RESET_LOADING = 'RESET_LOADING';\nexport const START_LOADING = 'START_LOADING';\nexport const STOP_LOADING = 'STOP_LOADING';\nexport const VALIDATE = 'VALIDATE';\nexport const CLEAR_MESSAGE = 'CLEAR_MESSAGE';\nexport const SHOW_MESSAGE = 'SHOW_MESSAGE';\n\nexport const createAction = type => payload => ({\n type,\n payload\n});\n\nexport const resetLoading = createAction(RESET_LOADING);\nexport const startLoading = createAction(START_LOADING);\nexport const stopLoading = createAction(STOP_LOADING);\n\nconst xhrs = {};\nconst etagCache = {};\n\nconst cancel = (key) => {\n if(xhrs[key]) {\n xhrs[key].abort();\n console.log(`aborted request ${key}`);\n delete xhrs[key];\n }\n}\n\nconst schedule = (key, req) => {\n // console.log(`scheduling ${key}`);\n xhrs[key] = req;\n};\n\nconst isObjectEmpty = (obj) => {\n return Object.keys(obj).length === 0 && obj.constructor === Object ;\n}\n\nexport const authErrorHandler = (err, res) => (dispatch, state) => {\n let code = err.status;\n let msg = '';\n\n dispatch(stopLoading());\n\n switch (code) {\n case 403:\n let error_message = {\n title: 'ERROR',\n html: T.translate(\"errors.user_not_authz\"),\n type: 'error'\n };\n\n dispatch(showMessage( error_message, initLogOut ));\n break;\n case 401:\n let currentLocation = getCurrentPathName();\n let clearing_session_state = isClearingSessionState();\n\n dispatch({\n type: CLEAR_SESSION_STATE,\n payload: {}\n });\n\n if(!clearing_session_state) {\n setSessionClearingState(true);\n console.log('authErrorHandler 401 - re login');\n doLogin(currentLocation);\n }\n break;\n case 404:\n msg = \"\";\n\n if (err.response.body && err.response.body.message) msg = err.response.body.message;\n else if (err.response.error && err.response.error.message) msg = err.response.error.message;\n else msg = err.message;\n\n Swal.fire(\"Not Found\", msg, \"warning\");\n\n break;\n case 412:\n for (var [key, value] of Object.entries(err.response.body.errors)) {\n if (isNaN(key)) {\n msg += key + ': ';\n }\n\n msg += value + '<br>';\n }\n Swal.fire(\"Validation error\", msg, \"warning\");\n dispatch({\n type: VALIDATE,\n payload: {errors: err.response.body.errors}\n });\n break;\n default:\n Swal.fire(\"ERROR\", T.translate(\"errors.server_error\"), \"error\");\n }\n}\n\nexport const getRequest =(\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {},\n useEtag = false\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n let key = url.toString();\n\n if(!isObjectEmpty(params)) {\n // remove the access token\n const { access_token: _, ...newParams} = params;\n // and generate new key\n key = url.query(newParams).toString();\n url = url.query(params);\n }\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n cancel(key);\n\n return new Promise((resolve, reject) => {\n let req = http.get(url.toString());\n if(useEtag && etagCache.hasOwnProperty(key)){\n const { etag } = etagCache[key];\n if(etag){\n req.set('If-None-Match', etag)\n }\n }\n\n req.timeout({\n response: 60000,\n deadline: 60000,\n })\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key, useEtag))\n\n schedule(key, req);\n });\n};\n\nexport const putRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => ( dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n http.put(url.toString())\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject))\n });\n};\n\nexport const deleteRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params) => (dispatch, state) => {\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n if(payload == null)\n payload = {};\n\n http.delete(url)\n .send(payload)\n .end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postRequest = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n payload,\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n let request = http.post(url);\n\n if(payload != null)\n request.send(payload);\n else // to be a simple CORS request\n request.set('Content-Type', 'text/plain');\n\n request.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const postFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.post(url)\n .attach('file', file);\n\n if(!isObjectEmpty(fileMetadata)) {\n Object.keys(fileMetadata).forEach(function (key) {\n let value = fileMetadata[key];\n req.field(key, value);\n });\n }\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const putFile = (\n requestActionCreator,\n receiveActionCreator,\n endpoint,\n file = null,\n fileMetadata = {},\n errorHandler = defaultErrorHandler,\n requestActionPayload = {}\n) => (params = {}) => (dispatch, state) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n if(requestActionCreator && typeof requestActionCreator === 'function')\n dispatch(requestActionCreator(requestActionPayload));\n\n return new Promise((resolve, reject) => {\n\n const req = http.put(url);\n\n if(file != null){\n req.attach('file', file);\n }\n\n if(!isObjectEmpty(fileMetadata)) {\n Object.keys(fileMetadata).forEach(function (key) {\n let value = fileMetadata[key];\n req.field(key, value);\n });\n }\n\n req.end(responseHandler(dispatch, state, receiveActionCreator, errorHandler, resolve, reject));\n });\n};\n\nexport const defaultErrorHandler = (err, res) => (dispatch) => {\n let body = res.body;\n let text = '';\n if(body instanceof Object){\n if(body.hasOwnProperty('message'))\n text = body.message;\n }\n Swal.fire(res.statusText, text, \"error\");\n}\n\nconst byLowerCase = toFind => value => toLowerCase(value) === toFind;\nconst toLowerCase = value => value.toLowerCase();\nconst getKeys = headers => Object.keys(headers);\n\nexport const getHeaderCaseInsensitive = (headerName, headers = {}) => {\n const key = getKeys(headers).find(byLowerCase(headerName));\n return key ? headers[key] : undefined;\n};\n\nexport const responseHandler = ( dispatch, state, receiveActionCreator, errorHandler, resolve, reject, key = null, useEtag= false ) =>\n\n (err, res) => {\n\n if (err || !res.ok) {\n let code = err.status;\n\n if(code === 304 && etagCache.hasOwnProperty(key) && useEtag){\n const { body } = etagCache[key];\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: body}));\n return resolve({response: body});\n }\n\n dispatch(receiveActionCreator);\n return resolve({response: body});\n }\n if(errorHandler) {\n errorHandler(err, res)(dispatch, state);\n }\n return reject({ err, res, dispatch, state })\n }\n\n let json = res.body;\n\n if(useEtag) {\n const responseETAG = getHeaderCaseInsensitive('etag', res.headers);\n if (responseETAG) {\n etagCache[key] = { etag: responseETAG, body: json};\n }\n }\n\n if(typeof receiveActionCreator === 'function') {\n dispatch(receiveActionCreator({response: json}));\n return resolve({response: json});\n }\n dispatch(receiveActionCreator);\n return resolve({response: json});\n}\n\n\nexport const fetchErrorHandler = (response) => {\n let code = response.status;\n let msg = response.statusText;\n\n switch (code) {\n case 403:\n Swal.fire(\"ERROR\", T.translate(\"errors.user_not_authz\"), \"warning\");\n break;\n case 401:\n Swal.fire(\"ERROR\", T.translate(\"errors.session_expired\"), \"error\");\n break;\n case 412:\n Swal.fire(\"ERROR\", msg, \"warning\");\n case 500:\n Swal.fire(\"ERROR\", T.translate(\"errors.server_error\"), \"error\");\n }\n}\n\nexport const fetchResponseHandler = (response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.json();\n }\n}\n\nexport const showMessage = (settings, callback = {}) => (dispatch) => {\n dispatch(stopLoading());\n\n Swal.fire(settings).then((result) => {\n if (result.value && typeof callback === 'function') {\n callback();\n }\n });\n}\n\nexport const showSuccessMessage = (html) => (dispatch) => {\n dispatch(stopLoading());\n Swal.fire({\n title: T.translate(\"general.done\"),\n html: html,\n type: 'success'\n });\n}\n\nexport const downloadFileByContent = (filename, content, mime) => {\n let link = document.createElement('a');\n link.textContent = 'download';\n link.download = filename;\n link.href = `data:${mime},${encodeURIComponent(content)}`\n document.body.appendChild(link); // Required for FF\n link.click();\n document.body.removeChild(link);\n}\n\nexport const getCSV = (endpoint, params, filename, header = null) => (dispatch) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n dispatch(startLoading());\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n dispatch(stopLoading());\n\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n downloadFileByContent(filename, csv, 'text/csv;charset=utf-8');\n })\n .catch(fetchErrorHandler);\n};\n\nexport const getRawCSV = (endpoint, params, header = null) => {\n\n let url = URI(endpoint);\n\n if(!isObjectEmpty(params))\n url = url.query(params);\n\n return fetch(url.toString())\n .then((response) => {\n if (!response.ok) {\n throw response;\n } else {\n return response.text();\n }\n })\n .then((csv) => {\n if (header) {\n csv = header + '\\r\\r' + csv;\n }\n\n return csv;\n })\n .catch(fetchErrorHandler);\n};\n\nexport const escapeFilterValue = (value) => {\n value = value.replace(/,/g, \"\\\\,\");\n value = value.replace(/;/g, \"\\\\;\");\n return value;\n};\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"idtoken-verifier\");","module.exports = require(\"moment-timezone\");","module.exports = require(\"superagent/lib/client\");","module.exports = require(\"sweetalert2\");","module.exports = require(\"urijs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/**\n * Copyright 2017 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport {\n CLEAR_MESSAGE,\n SHOW_MESSAGE,\n STOP_LOADING,\n} from './actions';\n\nconst DEFAULT_STATE = {\n msg: null,\n msg_type: null,\n params: {},\n loading: false,\n}\n\nexport const genericReducers = function ( state = DEFAULT_STATE, action = {}) {\n switch(action.type) {\n case SHOW_MESSAGE:\n return {\n ...state,\n msg: action.payload.msg,\n msg_type: action.payload.msg_type,\n };\n\n case CLEAR_MESSAGE:\n return { ...state, msg: null };\n\n case STOP_LOADING:\n return { ...state, loading: false };\n\n default:\n return state;\n }\n};\n"],"names":["root","factory","exports","module","define","amd","this","require","window","crypto","msCrypto","SuperTokensLock","STOP_LOADING","CLEAR_MESSAGE","SHOW_MESSAGE","createAction","type","payload","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","DEFAULT_STATE","msg","msg_type","params","loading","genericReducers","state","action"],"sourceRoot":""}
@@ -1,178 +1,2 @@
1
- (function webpackUniversalModuleDefinition(root, factory) {
2
- if(typeof exports === 'object' && typeof module === 'object')
3
- module.exports = factory();
4
- else if(typeof define === 'function' && define.amd)
5
- define("openstack-uicore-foundation", [], factory);
6
- else if(typeof exports === 'object')
7
- exports["openstack-uicore-foundation"] = factory();
8
- else
9
- root["openstack-uicore-foundation"] = factory();
10
- })(this, () => {
11
- return /******/ (() => { // webpackBootstrap
12
- /******/ "use strict";
13
- /******/ var __webpack_modules__ = ({
14
-
15
- /***/ "react":
16
- /*!************************!*\
17
- !*** external "react" ***!
18
- \************************/
19
- /***/ ((module) => {
20
-
21
- module.exports = require("react");
22
-
23
- /***/ })
24
-
25
- /******/ });
26
- /************************************************************************/
27
- /******/ // The module cache
28
- /******/ var __webpack_module_cache__ = {};
29
- /******/
30
- /******/ // The require function
31
- /******/ function __webpack_require__(moduleId) {
32
- /******/ // Check if module is in cache
33
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
34
- /******/ if (cachedModule !== undefined) {
35
- /******/ return cachedModule.exports;
36
- /******/ }
37
- /******/ // Create a new module (and put it into the cache)
38
- /******/ var module = __webpack_module_cache__[moduleId] = {
39
- /******/ // no module.id needed
40
- /******/ // no module.loaded needed
41
- /******/ exports: {}
42
- /******/ };
43
- /******/
44
- /******/ // Execute the module function
45
- /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
46
- /******/
47
- /******/ // Return the exports of the module
48
- /******/ return module.exports;
49
- /******/ }
50
- /******/
51
- /************************************************************************/
52
- /******/ /* webpack/runtime/compat get default export */
53
- /******/ (() => {
54
- /******/ // getDefaultExport function for compatibility with non-harmony modules
55
- /******/ __webpack_require__.n = (module) => {
56
- /******/ var getter = module && module.__esModule ?
57
- /******/ () => (module['default']) :
58
- /******/ () => (module);
59
- /******/ __webpack_require__.d(getter, { a: getter });
60
- /******/ return getter;
61
- /******/ };
62
- /******/ })();
63
- /******/
64
- /******/ /* webpack/runtime/define property getters */
65
- /******/ (() => {
66
- /******/ // define getter functions for harmony exports
67
- /******/ __webpack_require__.d = (exports, definition) => {
68
- /******/ for(var key in definition) {
69
- /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
70
- /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
71
- /******/ }
72
- /******/ }
73
- /******/ };
74
- /******/ })();
75
- /******/
76
- /******/ /* webpack/runtime/hasOwnProperty shorthand */
77
- /******/ (() => {
78
- /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
79
- /******/ })();
80
- /******/
81
- /******/ /* webpack/runtime/make namespace object */
82
- /******/ (() => {
83
- /******/ // define __esModule on exports
84
- /******/ __webpack_require__.r = (exports) => {
85
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
86
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
87
- /******/ }
88
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
89
- /******/ };
90
- /******/ })();
91
- /******/
92
- /************************************************************************/
93
- var __webpack_exports__ = {};
94
- // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
95
- (() => {
96
- /*!****************************************!*\
97
- !*** ./src/components/use-fit-text.js ***!
98
- \****************************************/
99
- __webpack_require__.r(__webpack_exports__);
100
- /* harmony export */ __webpack_require__.d(__webpack_exports__, {
101
- /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
102
- /* harmony export */ });
103
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react");
104
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
105
-
106
-
107
- const useFitText = (maxSize = 50, minSize = 130) => {
108
- const MIN_FONT_SIZE = minSize;
109
- const MAX_FONT_SIZE = maxSize;
110
- const RESOLUTION = 5;
111
- const ref = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);
112
- const [state, setState] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)({
113
- fontSize: MAX_FONT_SIZE,
114
- fontSizePrev: MIN_FONT_SIZE,
115
- fontSizeMax: MAX_FONT_SIZE,
116
- fontSizeMin: MIN_FONT_SIZE
117
- });
118
- const {
119
- fontSize,
120
- fontSizeMax,
121
- fontSizeMin,
122
- fontSizePrev
123
- } = state;
124
- (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
125
- const isDone = Math.abs(fontSize - fontSizePrev) <= RESOLUTION;
126
- const isOverflow = !!ref.current && (ref.current.scrollHeight > ref.current.offsetHeight || ref.current.scrollWidth > ref.current.offsetWidth);
127
- const isAsc = fontSize > fontSizePrev; // return if the font size has been adjusted "enough" (change within RESOLUTION)
128
- // reduce font size by one increment if it's overflowing
129
-
130
- if (isDone) {
131
- if (isOverflow) {
132
- const fontSizeNew = fontSizePrev < fontSize ? fontSizePrev : fontSize - (fontSizePrev - fontSize);
133
- setState({
134
- fontSize: fontSizeNew,
135
- fontSizeMax,
136
- fontSizeMin,
137
- fontSizePrev
138
- });
139
- }
140
-
141
- return;
142
- } // binary search to adjust font size
143
-
144
-
145
- let delta;
146
- let newMax = fontSizeMax;
147
- let newMin = fontSizeMin;
148
-
149
- if (isOverflow) {
150
- delta = isAsc ? fontSizePrev - fontSize : fontSizeMin - fontSize;
151
- newMax = Math.min(fontSizeMax, fontSize);
152
- } else {
153
- delta = isAsc ? fontSizeMax - fontSize : fontSizePrev - fontSize;
154
- newMin = Math.max(fontSizeMin, fontSize);
155
- }
156
-
157
- setState({
158
- fontSize: fontSize + delta / 2,
159
- fontSizeMax: newMax,
160
- fontSizeMin: newMin,
161
- fontSizePrev: fontSize
162
- });
163
- }, [fontSize, fontSizeMax, fontSizeMin, fontSizePrev, ref]);
164
- return {
165
- fontSize: `${fontSize}%`,
166
- lineHeight: `${fontSize - 10}%`,
167
- ref
168
- };
169
- };
170
-
171
- /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (useFitText);
172
- })();
173
-
174
- /******/ return __webpack_exports__;
175
- /******/ })()
176
- ;
177
- });
178
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMvdXNlLWZpdC10ZXh0LmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLENBQUM7QUFDRCxPOzs7Ozs7Ozs7O0FDVkE7Ozs7OztVQ0FBO1VBQ0E7O1VBRUE7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7VUFDQTtVQUNBO1VBQ0E7O1VBRUE7VUFDQTs7VUFFQTtVQUNBO1VBQ0E7Ozs7O1dDdEJBO1dBQ0E7V0FDQTtXQUNBO1dBQ0E7V0FDQSxpQ0FBaUMsV0FBVztXQUM1QztXQUNBOzs7OztXQ1BBO1dBQ0E7V0FDQTtXQUNBO1dBQ0EseUNBQXlDLHdDQUF3QztXQUNqRjtXQUNBO1dBQ0E7Ozs7O1dDUEE7Ozs7O1dDQUE7V0FDQTtXQUNBO1dBQ0EsdURBQXVELGlCQUFpQjtXQUN4RTtXQUNBLGdEQUFnRCxhQUFhO1dBQzdEOzs7Ozs7Ozs7Ozs7Ozs7O0FDTkE7O0FBRUEsTUFBTUcsVUFBVSxHQUFHLENBQUNDLE9BQU8sR0FBRyxFQUFYLEVBQWVDLE9BQU8sR0FBRyxHQUF6QixLQUFpQztFQUNoRCxNQUFNQyxhQUFhLEdBQUdELE9BQXRCO0VBQ0EsTUFBTUUsYUFBYSxHQUFHSCxPQUF0QjtFQUNBLE1BQU1JLFVBQVUsR0FBRyxDQUFuQjtFQUVBLE1BQU1DLEdBQUcsR0FBR1QsNkNBQU0sQ0FBQyxJQUFELENBQWxCO0VBRUEsTUFBTSxDQUFDVSxLQUFELEVBQVFDLFFBQVIsSUFBb0JWLCtDQUFRLENBQUM7SUFDL0JXLFFBQVEsRUFBRUwsYUFEcUI7SUFFL0JNLFlBQVksRUFBRVAsYUFGaUI7SUFHL0JRLFdBQVcsRUFBRVAsYUFIa0I7SUFJL0JRLFdBQVcsRUFBRVQ7RUFKa0IsQ0FBRCxDQUFsQztFQU1BLE1BQU07SUFBRU0sUUFBRjtJQUFZRSxXQUFaO0lBQXlCQyxXQUF6QjtJQUFzQ0Y7RUFBdEMsSUFBdURILEtBQTdEO0VBRUFSLGdEQUFTLENBQUMsTUFBTTtJQUNaLE1BQU1jLE1BQU0sR0FBR0MsSUFBSSxDQUFDQyxHQUFMLENBQVNOLFFBQVEsR0FBR0MsWUFBcEIsS0FBcUNMLFVBQXBEO0lBQ0EsTUFBTVcsVUFBVSxHQUNaLENBQUMsQ0FBQ1YsR0FBRyxDQUFDVyxPQUFOLEtBQ0NYLEdBQUcsQ0FBQ1csT0FBSixDQUFZQyxZQUFaLEdBQTJCWixHQUFHLENBQUNXLE9BQUosQ0FBWUUsWUFBdkMsSUFDR2IsR0FBRyxDQUFDVyxPQUFKLENBQVlHLFdBQVosR0FBMEJkLEdBQUcsQ0FBQ1csT0FBSixDQUFZSSxXQUYxQyxDQURKO0lBSUEsTUFBTUMsS0FBSyxHQUFHYixRQUFRLEdBQUdDLFlBQXpCLENBTlksQ0FRWjtJQUNBOztJQUNBLElBQUlHLE1BQUosRUFBWTtNQUNSLElBQUlHLFVBQUosRUFBZ0I7UUFDWixNQUFNTyxXQUFXLEdBQ2JiLFlBQVksR0FBR0QsUUFBZixHQUNNQyxZQUROLEdBRU1ELFFBQVEsSUFBSUMsWUFBWSxHQUFHRCxRQUFuQixDQUhsQjtRQUlBRCxRQUFRLENBQUM7VUFDTEMsUUFBUSxFQUFFYyxXQURMO1VBRUxaLFdBRks7VUFHTEMsV0FISztVQUlMRjtRQUpLLENBQUQsQ0FBUjtNQU1IOztNQUNEO0lBQ0gsQ0F4QlcsQ0EwQlo7OztJQUNBLElBQUljLEtBQUo7SUFDQSxJQUFJQyxNQUFNLEdBQUdkLFdBQWI7SUFDQSxJQUFJZSxNQUFNLEdBQUdkLFdBQWI7O0lBQ0EsSUFBSUksVUFBSixFQUFnQjtNQUNaUSxLQUFLLEdBQUdGLEtBQUssR0FBR1osWUFBWSxHQUFHRCxRQUFsQixHQUE2QkcsV0FBVyxHQUFHSCxRQUF4RDtNQUNBZ0IsTUFBTSxHQUFHWCxJQUFJLENBQUNhLEdBQUwsQ0FBU2hCLFdBQVQsRUFBc0JGLFFBQXRCLENBQVQ7SUFDSCxDQUhELE1BR087TUFDSGUsS0FBSyxHQUFHRixLQUFLLEdBQUdYLFdBQVcsR0FBR0YsUUFBakIsR0FBNEJDLFlBQVksR0FBR0QsUUFBeEQ7TUFDQWlCLE1BQU0sR0FBR1osSUFBSSxDQUFDYyxHQUFMLENBQVNoQixXQUFULEVBQXNCSCxRQUF0QixDQUFUO0lBQ0g7O0lBQ0RELFFBQVEsQ0FBQztNQUNMQyxRQUFRLEVBQUVBLFFBQVEsR0FBR2UsS0FBSyxHQUFHLENBRHhCO01BRUxiLFdBQVcsRUFBRWMsTUFGUjtNQUdMYixXQUFXLEVBQUVjLE1BSFI7TUFJTGhCLFlBQVksRUFBRUQ7SUFKVCxDQUFELENBQVI7RUFNSCxDQTNDUSxFQTJDTixDQUFDQSxRQUFELEVBQVdFLFdBQVgsRUFBd0JDLFdBQXhCLEVBQXFDRixZQUFyQyxFQUFtREosR0FBbkQsQ0EzQ00sQ0FBVDtFQTZDQSxPQUFPO0lBQUVHLFFBQVEsRUFBRyxHQUFFQSxRQUFTLEdBQXhCO0lBQTRCb0IsVUFBVSxFQUFHLEdBQUVwQixRQUFRLEdBQUcsRUFBRyxHQUF6RDtJQUE2REg7RUFBN0QsQ0FBUDtBQUNILENBN0REOztBQStEQSxpRUFBZU4sVUFBZixFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vb3BlbnN0YWNrLXVpY29yZS1mb3VuZGF0aW9uL3dlYnBhY2svdW5pdmVyc2FsTW9kdWxlRGVmaW5pdGlvbiIsIndlYnBhY2s6Ly9vcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb24vZXh0ZXJuYWwgY29tbW9uanMgXCJyZWFjdFwiIiwid2VicGFjazovL29wZW5zdGFjay11aWNvcmUtZm91bmRhdGlvbi93ZWJwYWNrL2Jvb3RzdHJhcCIsIndlYnBhY2s6Ly9vcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb24vd2VicGFjay9ydW50aW1lL2NvbXBhdCBnZXQgZGVmYXVsdCBleHBvcnQiLCJ3ZWJwYWNrOi8vb3BlbnN0YWNrLXVpY29yZS1mb3VuZGF0aW9uL3dlYnBhY2svcnVudGltZS9kZWZpbmUgcHJvcGVydHkgZ2V0dGVycyIsIndlYnBhY2s6Ly9vcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb24vd2VicGFjay9ydW50aW1lL2hhc093blByb3BlcnR5IHNob3J0aGFuZCIsIndlYnBhY2s6Ly9vcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb24vd2VicGFjay9ydW50aW1lL21ha2UgbmFtZXNwYWNlIG9iamVjdCIsIndlYnBhY2s6Ly9vcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb24vLi9zcmMvY29tcG9uZW50cy91c2UtZml0LXRleHQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uIHdlYnBhY2tVbml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uKHJvb3QsIGZhY3RvcnkpIHtcblx0aWYodHlwZW9mIGV4cG9ydHMgPT09ICdvYmplY3QnICYmIHR5cGVvZiBtb2R1bGUgPT09ICdvYmplY3QnKVxuXHRcdG1vZHVsZS5leHBvcnRzID0gZmFjdG9yeSgpO1xuXHRlbHNlIGlmKHR5cGVvZiBkZWZpbmUgPT09ICdmdW5jdGlvbicgJiYgZGVmaW5lLmFtZClcblx0XHRkZWZpbmUoXCJvcGVuc3RhY2stdWljb3JlLWZvdW5kYXRpb25cIiwgW10sIGZhY3RvcnkpO1xuXHRlbHNlIGlmKHR5cGVvZiBleHBvcnRzID09PSAnb2JqZWN0Jylcblx0XHRleHBvcnRzW1wib3BlbnN0YWNrLXVpY29yZS1mb3VuZGF0aW9uXCJdID0gZmFjdG9yeSgpO1xuXHRlbHNlXG5cdFx0cm9vdFtcIm9wZW5zdGFjay11aWNvcmUtZm91bmRhdGlvblwiXSA9IGZhY3RvcnkoKTtcbn0pKHRoaXMsICgpID0+IHtcbnJldHVybiAiLCJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJyZWFjdFwiKTsiLCIvLyBUaGUgbW9kdWxlIGNhY2hlXG52YXIgX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fID0ge307XG5cbi8vIFRoZSByZXF1aXJlIGZ1bmN0aW9uXG5mdW5jdGlvbiBfX3dlYnBhY2tfcmVxdWlyZV9fKG1vZHVsZUlkKSB7XG5cdC8vIENoZWNrIGlmIG1vZHVsZSBpcyBpbiBjYWNoZVxuXHR2YXIgY2FjaGVkTW9kdWxlID0gX193ZWJwYWNrX21vZHVsZV9jYWNoZV9fW21vZHVsZUlkXTtcblx0aWYgKGNhY2hlZE1vZHVsZSAhPT0gdW5kZWZpbmVkKSB7XG5cdFx0cmV0dXJuIGNhY2hlZE1vZHVsZS5leHBvcnRzO1xuXHR9XG5cdC8vIENyZWF0ZSBhIG5ldyBtb2R1bGUgKGFuZCBwdXQgaXQgaW50byB0aGUgY2FjaGUpXG5cdHZhciBtb2R1bGUgPSBfX3dlYnBhY2tfbW9kdWxlX2NhY2hlX19bbW9kdWxlSWRdID0ge1xuXHRcdC8vIG5vIG1vZHVsZS5pZCBuZWVkZWRcblx0XHQvLyBubyBtb2R1bGUubG9hZGVkIG5lZWRlZFxuXHRcdGV4cG9ydHM6IHt9XG5cdH07XG5cblx0Ly8gRXhlY3V0ZSB0aGUgbW9kdWxlIGZ1bmN0aW9uXG5cdF9fd2VicGFja19tb2R1bGVzX19bbW9kdWxlSWRdKG1vZHVsZSwgbW9kdWxlLmV4cG9ydHMsIF9fd2VicGFja19yZXF1aXJlX18pO1xuXG5cdC8vIFJldHVybiB0aGUgZXhwb3J0cyBvZiB0aGUgbW9kdWxlXG5cdHJldHVybiBtb2R1bGUuZXhwb3J0cztcbn1cblxuIiwiLy8gZ2V0RGVmYXVsdEV4cG9ydCBmdW5jdGlvbiBmb3IgY29tcGF0aWJpbGl0eSB3aXRoIG5vbi1oYXJtb255IG1vZHVsZXNcbl9fd2VicGFja19yZXF1aXJlX18ubiA9IChtb2R1bGUpID0+IHtcblx0dmFyIGdldHRlciA9IG1vZHVsZSAmJiBtb2R1bGUuX19lc01vZHVsZSA/XG5cdFx0KCkgPT4gKG1vZHVsZVsnZGVmYXVsdCddKSA6XG5cdFx0KCkgPT4gKG1vZHVsZSk7XG5cdF9fd2VicGFja19yZXF1aXJlX18uZChnZXR0ZXIsIHsgYTogZ2V0dGVyIH0pO1xuXHRyZXR1cm4gZ2V0dGVyO1xufTsiLCIvLyBkZWZpbmUgZ2V0dGVyIGZ1bmN0aW9ucyBmb3IgaGFybW9ueSBleHBvcnRzXG5fX3dlYnBhY2tfcmVxdWlyZV9fLmQgPSAoZXhwb3J0cywgZGVmaW5pdGlvbikgPT4ge1xuXHRmb3IodmFyIGtleSBpbiBkZWZpbml0aW9uKSB7XG5cdFx0aWYoX193ZWJwYWNrX3JlcXVpcmVfXy5vKGRlZmluaXRpb24sIGtleSkgJiYgIV9fd2VicGFja19yZXF1aXJlX18ubyhleHBvcnRzLCBrZXkpKSB7XG5cdFx0XHRPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywga2V5LCB7IGVudW1lcmFibGU6IHRydWUsIGdldDogZGVmaW5pdGlvbltrZXldIH0pO1xuXHRcdH1cblx0fVxufTsiLCJfX3dlYnBhY2tfcmVxdWlyZV9fLm8gPSAob2JqLCBwcm9wKSA9PiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG9iaiwgcHJvcCkpIiwiLy8gZGVmaW5lIF9fZXNNb2R1bGUgb24gZXhwb3J0c1xuX193ZWJwYWNrX3JlcXVpcmVfXy5yID0gKGV4cG9ydHMpID0+IHtcblx0aWYodHlwZW9mIFN5bWJvbCAhPT0gJ3VuZGVmaW5lZCcgJiYgU3ltYm9sLnRvU3RyaW5nVGFnKSB7XG5cdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cdH1cblx0T2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsICdfX2VzTW9kdWxlJywgeyB2YWx1ZTogdHJ1ZSB9KTtcbn07IiwiaW1wb3J0IHsgdXNlUmVmLCB1c2VTdGF0ZSwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuXG5jb25zdCB1c2VGaXRUZXh0ID0gKG1heFNpemUgPSA1MCwgbWluU2l6ZSA9IDEzMCkgPT4ge1xuICAgIGNvbnN0IE1JTl9GT05UX1NJWkUgPSBtaW5TaXplO1xuICAgIGNvbnN0IE1BWF9GT05UX1NJWkUgPSBtYXhTaXplO1xuICAgIGNvbnN0IFJFU09MVVRJT04gPSA1O1xuXG4gICAgY29uc3QgcmVmID0gdXNlUmVmKG51bGwpO1xuXG4gICAgY29uc3QgW3N0YXRlLCBzZXRTdGF0ZV0gPSB1c2VTdGF0ZSh7XG4gICAgICAgIGZvbnRTaXplOiBNQVhfRk9OVF9TSVpFLFxuICAgICAgICBmb250U2l6ZVByZXY6IE1JTl9GT05UX1NJWkUsXG4gICAgICAgIGZvbnRTaXplTWF4OiBNQVhfRk9OVF9TSVpFLFxuICAgICAgICBmb250U2l6ZU1pbjogTUlOX0ZPTlRfU0laRSxcbiAgICB9KTtcbiAgICBjb25zdCB7IGZvbnRTaXplLCBmb250U2l6ZU1heCwgZm9udFNpemVNaW4sIGZvbnRTaXplUHJldiB9ID0gc3RhdGU7XG5cbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgICBjb25zdCBpc0RvbmUgPSBNYXRoLmFicyhmb250U2l6ZSAtIGZvbnRTaXplUHJldikgPD0gUkVTT0xVVElPTjtcbiAgICAgICAgY29uc3QgaXNPdmVyZmxvdyA9XG4gICAgICAgICAgICAhIXJlZi5jdXJyZW50ICYmXG4gICAgICAgICAgICAocmVmLmN1cnJlbnQuc2Nyb2xsSGVpZ2h0ID4gcmVmLmN1cnJlbnQub2Zmc2V0SGVpZ2h0IHx8XG4gICAgICAgICAgICAgICAgcmVmLmN1cnJlbnQuc2Nyb2xsV2lkdGggPiByZWYuY3VycmVudC5vZmZzZXRXaWR0aCk7XG4gICAgICAgIGNvbnN0IGlzQXNjID0gZm9udFNpemUgPiBmb250U2l6ZVByZXY7XG5cbiAgICAgICAgLy8gcmV0dXJuIGlmIHRoZSBmb250IHNpemUgaGFzIGJlZW4gYWRqdXN0ZWQgXCJlbm91Z2hcIiAoY2hhbmdlIHdpdGhpbiBSRVNPTFVUSU9OKVxuICAgICAgICAvLyByZWR1Y2UgZm9udCBzaXplIGJ5IG9uZSBpbmNyZW1lbnQgaWYgaXQncyBvdmVyZmxvd2luZ1xuICAgICAgICBpZiAoaXNEb25lKSB7XG4gICAgICAgICAgICBpZiAoaXNPdmVyZmxvdykge1xuICAgICAgICAgICAgICAgIGNvbnN0IGZvbnRTaXplTmV3ID1cbiAgICAgICAgICAgICAgICAgICAgZm9udFNpemVQcmV2IDwgZm9udFNpemVcbiAgICAgICAgICAgICAgICAgICAgICAgID8gZm9udFNpemVQcmV2XG4gICAgICAgICAgICAgICAgICAgICAgICA6IGZvbnRTaXplIC0gKGZvbnRTaXplUHJldiAtIGZvbnRTaXplKTtcbiAgICAgICAgICAgICAgICBzZXRTdGF0ZSh7XG4gICAgICAgICAgICAgICAgICAgIGZvbnRTaXplOiBmb250U2l6ZU5ldyxcbiAgICAgICAgICAgICAgICAgICAgZm9udFNpemVNYXgsXG4gICAgICAgICAgICAgICAgICAgIGZvbnRTaXplTWluLFxuICAgICAgICAgICAgICAgICAgICBmb250U2l6ZVByZXYsXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICAvLyBiaW5hcnkgc2VhcmNoIHRvIGFkanVzdCBmb250IHNpemVcbiAgICAgICAgbGV0IGRlbHRhO1xuICAgICAgICBsZXQgbmV3TWF4ID0gZm9udFNpemVNYXg7XG4gICAgICAgIGxldCBuZXdNaW4gPSBmb250U2l6ZU1pbjtcbiAgICAgICAgaWYgKGlzT3ZlcmZsb3cpIHtcbiAgICAgICAgICAgIGRlbHRhID0gaXNBc2MgPyBmb250U2l6ZVByZXYgLSBmb250U2l6ZSA6IGZvbnRTaXplTWluIC0gZm9udFNpemU7XG4gICAgICAgICAgICBuZXdNYXggPSBNYXRoLm1pbihmb250U2l6ZU1heCwgZm9udFNpemUpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVsdGEgPSBpc0FzYyA/IGZvbnRTaXplTWF4IC0gZm9udFNpemUgOiBmb250U2l6ZVByZXYgLSBmb250U2l6ZTtcbiAgICAgICAgICAgIG5ld01pbiA9IE1hdGgubWF4KGZvbnRTaXplTWluLCBmb250U2l6ZSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0U3RhdGUoe1xuICAgICAgICAgICAgZm9udFNpemU6IGZvbnRTaXplICsgZGVsdGEgLyAyLFxuICAgICAgICAgICAgZm9udFNpemVNYXg6IG5ld01heCxcbiAgICAgICAgICAgIGZvbnRTaXplTWluOiBuZXdNaW4sXG4gICAgICAgICAgICBmb250U2l6ZVByZXY6IGZvbnRTaXplLFxuICAgICAgICB9KTtcbiAgICB9LCBbZm9udFNpemUsIGZvbnRTaXplTWF4LCBmb250U2l6ZU1pbiwgZm9udFNpemVQcmV2LCByZWZdKTtcblxuICAgIHJldHVybiB7IGZvbnRTaXplOiBgJHtmb250U2l6ZX0lYCwgbGluZUhlaWdodDogYCR7Zm9udFNpemUgLSAxMH0lYCwgcmVmIH07XG59O1xuXG5leHBvcnQgZGVmYXVsdCB1c2VGaXRUZXh0O1xuIl0sIm5hbWVzIjpbInVzZVJlZiIsInVzZVN0YXRlIiwidXNlRWZmZWN0IiwidXNlRml0VGV4dCIsIm1heFNpemUiLCJtaW5TaXplIiwiTUlOX0ZPTlRfU0laRSIsIk1BWF9GT05UX1NJWkUiLCJSRVNPTFVUSU9OIiwicmVmIiwic3RhdGUiLCJzZXRTdGF0ZSIsImZvbnRTaXplIiwiZm9udFNpemVQcmV2IiwiZm9udFNpemVNYXgiLCJmb250U2l6ZU1pbiIsImlzRG9uZSIsIk1hdGgiLCJhYnMiLCJpc092ZXJmbG93IiwiY3VycmVudCIsInNjcm9sbEhlaWdodCIsIm9mZnNldEhlaWdodCIsInNjcm9sbFdpZHRoIiwib2Zmc2V0V2lkdGgiLCJpc0FzYyIsImZvbnRTaXplTmV3IiwiZGVsdGEiLCJuZXdNYXgiLCJuZXdNaW4iLCJtaW4iLCJtYXgiLCJsaW5lSGVpZ2h0Il0sInNvdXJjZVJvb3QiOiIifQ==
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("openstack-uicore-foundation",[],t):"object"==typeof exports?exports["openstack-uicore-foundation"]=t():e["openstack-uicore-foundation"]=t()}(this,(()=>(()=>{"use strict";var e={};(()=>{e.d=(t,o)=>{for(var n in o)e.o(o,n)&&!e.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:o[n]})}})(),(()=>{e.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t)})(),(()=>{e.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}})();var t={};e.r(t),e.d(t,{default:()=>n});const o=require("react"),n=(e=50,t=130)=>{const n=t,r=e,i=(0,o.useRef)(null),[f,u]=(0,o.useState)({fontSize:r,fontSizePrev:n,fontSizeMax:r,fontSizeMin:n}),{fontSize:a,fontSizeMax:c,fontSizeMin:s,fontSizePrev:S}=f;return(0,o.useEffect)((()=>{const e=Math.abs(a-S)<=5,t=!!i.current&&(i.current.scrollHeight>i.current.offsetHeight||i.current.scrollWidth>i.current.offsetWidth),o=a>S;if(e){if(t){u({fontSize:S<a?S:a-(S-a),fontSizeMax:c,fontSizeMin:s,fontSizePrev:S})}return}let n,r=c,f=s;t?(n=o?S-a:s-a,r=Math.min(c,a)):(n=o?c-a:S-a,f=Math.max(s,a)),u({fontSize:a+n/2,fontSizeMax:r,fontSizeMin:f,fontSizePrev:a})}),[a,c,s,S,i]),{fontSize:`${a}%`,lineHeight:a-10+"%",ref:i}};return t})()));
2
+ //# sourceMappingURL=use-fit-text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils/use-fit-text.js","mappings":"CAAA,SAA2CA,EAAMC,GAC1B,iBAAZC,SAA0C,iBAAXC,OACxCA,OAAOD,QAAUD,IACQ,mBAAXG,QAAyBA,OAAOC,IAC9CD,OAAO,8BAA+B,GAAIH,GAChB,iBAAZC,QACdA,QAAQ,+BAAiCD,IAEzCD,EAAK,+BAAiCC,GACvC,CATD,CASGK,MAAM,I,mBCRT,IAAIC,EAAsB,CAAC,E,MCA3BA,EAAoBC,EAAI,CAACN,EAASO,KACjC,IAAI,IAAIC,KAAOD,EACXF,EAAoBI,EAAEF,EAAYC,KAASH,EAAoBI,EAAET,EAASQ,IAC5EE,OAAOC,eAAeX,EAASQ,EAAK,CAAEI,YAAY,EAAMC,IAAKN,EAAWC,IAE1E,C,WCNDH,EAAoBI,EAAI,CAACK,EAAKC,IAAUL,OAAOM,UAAUC,eAAeC,KAAKJ,EAAKC,E,WCClFV,EAAoBc,EAAKnB,IACH,oBAAXoB,QAA0BA,OAAOC,aAC1CX,OAAOC,eAAeX,EAASoB,OAAOC,YAAa,CAAEC,MAAO,WAE7DZ,OAAOC,eAAeX,EAAS,aAAc,CAAEsB,OAAO,GAAO,C,4CCL9D,MAAM,EAA+BC,QAAQ,SCiE7C,EA/DmB,CAACC,EAAU,GAAIC,EAAU,OACxC,MAAMC,EAAgBD,EAChBE,EAAgBH,EAGhBI,GAAMC,EAAAA,EAAAA,QAAO,OAEZC,EAAOC,IAAYC,EAAAA,EAAAA,UAAS,CAC/BC,SAAUN,EACVO,aAAcR,EACdS,YAAaR,EACbS,YAAaV,KAEX,SAAEO,EAAF,YAAYE,EAAZ,YAAyBC,EAAzB,aAAsCF,GAAiBJ,EA+C7D,OA7CAO,EAAAA,EAAAA,YAAU,KACN,MAAMC,EAASC,KAAKC,IAAIP,EAAWC,IAbpB,EAcTO,IACAb,EAAIc,UACLd,EAAIc,QAAQC,aAAef,EAAIc,QAAQE,cACpChB,EAAIc,QAAQG,YAAcjB,EAAIc,QAAQI,aACxCC,EAAQd,EAAWC,EAIzB,GAAII,EAAQ,CACR,GAAIG,EAAY,CAKZV,EAAS,CACLE,SAJAC,EAAeD,EACTC,EACAD,GAAYC,EAAeD,GAGjCE,cACAC,cACAF,gBAEP,CACD,MACH,CAGD,IAAIc,EACAC,EAASd,EACTe,EAASd,EACTK,GACAO,EAAQD,EAAQb,EAAeD,EAAWG,EAAcH,EACxDgB,EAASV,KAAKY,IAAIhB,EAAaF,KAE/Be,EAAQD,EAAQZ,EAAcF,EAAWC,EAAeD,EACxDiB,EAASX,KAAKa,IAAIhB,EAAaH,IAEnCF,EAAS,CACLE,SAAUA,EAAWe,EAAQ,EAC7Bb,YAAac,EACbb,YAAac,EACbhB,aAAcD,GAJlB,GAMD,CAACA,EAAUE,EAAaC,EAAaF,EAAcN,IAE/C,CAAEK,SAAW,GAAEA,KAAaoB,WAAepB,EAAW,GAAb,IAAoBL,MAApE,E","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/./src/components/use-fit-text.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react\");","import { useRef, useState, useEffect } from 'react';\n\nconst useFitText = (maxSize = 50, minSize = 130) => {\n const MIN_FONT_SIZE = minSize;\n const MAX_FONT_SIZE = maxSize;\n const RESOLUTION = 5;\n\n const ref = useRef(null);\n\n const [state, setState] = useState({\n fontSize: MAX_FONT_SIZE,\n fontSizePrev: MIN_FONT_SIZE,\n fontSizeMax: MAX_FONT_SIZE,\n fontSizeMin: MIN_FONT_SIZE,\n });\n const { fontSize, fontSizeMax, fontSizeMin, fontSizePrev } = state;\n\n useEffect(() => {\n const isDone = Math.abs(fontSize - fontSizePrev) <= RESOLUTION;\n const isOverflow =\n !!ref.current &&\n (ref.current.scrollHeight > ref.current.offsetHeight ||\n ref.current.scrollWidth > ref.current.offsetWidth);\n const isAsc = fontSize > fontSizePrev;\n\n // return if the font size has been adjusted \"enough\" (change within RESOLUTION)\n // reduce font size by one increment if it's overflowing\n if (isDone) {\n if (isOverflow) {\n const fontSizeNew =\n fontSizePrev < fontSize\n ? fontSizePrev\n : fontSize - (fontSizePrev - fontSize);\n setState({\n fontSize: fontSizeNew,\n fontSizeMax,\n fontSizeMin,\n fontSizePrev,\n });\n }\n return;\n }\n\n // binary search to adjust font size\n let delta;\n let newMax = fontSizeMax;\n let newMin = fontSizeMin;\n if (isOverflow) {\n delta = isAsc ? fontSizePrev - fontSize : fontSizeMin - fontSize;\n newMax = Math.min(fontSizeMax, fontSize);\n } else {\n delta = isAsc ? fontSizeMax - fontSize : fontSizePrev - fontSize;\n newMin = Math.max(fontSizeMin, fontSize);\n }\n setState({\n fontSize: fontSize + delta / 2,\n fontSizeMax: newMax,\n fontSizeMin: newMin,\n fontSizePrev: fontSize,\n });\n }, [fontSize, fontSizeMax, fontSizeMin, fontSizePrev, ref]);\n\n return { fontSize: `${fontSize}%`, lineHeight: `${fontSize - 10}%`, ref };\n};\n\nexport default useFitText;\n"],"names":["root","factory","exports","module","define","amd","this","__webpack_require__","d","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","require","maxSize","minSize","MIN_FONT_SIZE","MAX_FONT_SIZE","ref","useRef","state","setState","useState","fontSize","fontSizePrev","fontSizeMax","fontSizeMin","useEffect","isDone","Math","abs","isOverflow","current","scrollHeight","offsetHeight","scrollWidth","offsetWidth","isAsc","delta","newMax","newMin","min","max","lineHeight"],"sourceRoot":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "openstack-uicore-foundation",
3
- "version": "4.1.43",
3
+ "version": "4.1.44",
4
4
  "description": "ui reactjs components for openstack marketing site",
5
5
  "main": "lib/openstack-uicore-foundation.js",
6
6
  "scripts": {