@atlaskit/editor-plugin-extension 0.4.2 → 0.5.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 (307) hide show
  1. package/.eslintrc.js +26 -0
  2. package/CHANGELOG.md +16 -0
  3. package/dist/cjs/actions.js +236 -0
  4. package/dist/cjs/commands.js +122 -0
  5. package/dist/cjs/context-panel.js +269 -0
  6. package/dist/cjs/extension-api.js +266 -0
  7. package/dist/cjs/index.js +8 -1
  8. package/dist/cjs/plugin-factory.js +32 -0
  9. package/dist/cjs/plugin-key.js +8 -0
  10. package/dist/cjs/plugin.js +147 -0
  11. package/dist/cjs/pm-plugins/keymap.js +21 -0
  12. package/dist/cjs/pm-plugins/macro/actions.js +186 -0
  13. package/dist/cjs/pm-plugins/macro/index.js +72 -0
  14. package/dist/cjs/pm-plugins/macro/plugin-key.js +8 -0
  15. package/dist/cjs/pm-plugins/macro/types.js +5 -0
  16. package/dist/cjs/pm-plugins/main.js +323 -0
  17. package/dist/cjs/pm-plugins/unique-id.js +80 -0
  18. package/dist/cjs/pm-plugins/utils.js +75 -0
  19. package/dist/cjs/reducer.js +18 -0
  20. package/dist/cjs/toolbar.js +242 -0
  21. package/dist/cjs/ui/ConfigPanel/ConfigPanel.js +475 -0
  22. package/dist/cjs/ui/ConfigPanel/ConfigPanelFieldsLoader.js +122 -0
  23. package/dist/cjs/ui/ConfigPanel/ConfigPanelLoader.js +23 -0
  24. package/dist/cjs/ui/ConfigPanel/ErrorMessage/ErrorImage.js +76 -0
  25. package/dist/cjs/ui/ConfigPanel/ErrorMessage/index.js +33 -0
  26. package/dist/cjs/ui/ConfigPanel/FieldMessages.js +105 -0
  27. package/dist/cjs/ui/ConfigPanel/Fields/Boolean.js +150 -0
  28. package/dist/cjs/ui/ConfigPanel/Fields/CheckboxGroup.js +101 -0
  29. package/dist/cjs/ui/ConfigPanel/Fields/ColorPicker.js +420 -0
  30. package/dist/cjs/ui/ConfigPanel/Fields/CustomSelect.js +192 -0
  31. package/dist/cjs/ui/ConfigPanel/Fields/Date.js +55 -0
  32. package/dist/cjs/ui/ConfigPanel/Fields/DateRange.js +160 -0
  33. package/dist/cjs/ui/ConfigPanel/Fields/Enum.js +41 -0
  34. package/dist/cjs/ui/ConfigPanel/Fields/Expand.js +88 -0
  35. package/dist/cjs/ui/ConfigPanel/Fields/Fieldset.js +270 -0
  36. package/dist/cjs/ui/ConfigPanel/Fields/Number.js +64 -0
  37. package/dist/cjs/ui/ConfigPanel/Fields/RadioGroup.js +56 -0
  38. package/dist/cjs/ui/ConfigPanel/Fields/Select.js +60 -0
  39. package/dist/cjs/ui/ConfigPanel/Fields/SelectItem.js +53 -0
  40. package/dist/cjs/ui/ConfigPanel/Fields/String.js +75 -0
  41. package/dist/cjs/ui/ConfigPanel/Fields/TabGroup.js +73 -0
  42. package/dist/cjs/ui/ConfigPanel/Fields/UnhandledType.js +19 -0
  43. package/dist/cjs/ui/ConfigPanel/Fields/UserSelect.js +268 -0
  44. package/dist/cjs/ui/ConfigPanel/Fields/common/RequiredIndicator.js +12 -0
  45. package/dist/cjs/ui/ConfigPanel/FormContent.js +231 -0
  46. package/dist/cjs/ui/ConfigPanel/FormErrorBoundary.js +140 -0
  47. package/dist/cjs/ui/ConfigPanel/Header.js +148 -0
  48. package/dist/cjs/ui/ConfigPanel/LoadingState.js +25 -0
  49. package/dist/cjs/ui/ConfigPanel/NestedForms/RemovableField.js +61 -0
  50. package/dist/cjs/ui/ConfigPanel/constants.js +13 -0
  51. package/dist/cjs/ui/ConfigPanel/index.js +9 -0
  52. package/dist/cjs/ui/ConfigPanel/messages.js +99 -0
  53. package/dist/cjs/ui/ConfigPanel/transformers.js +631 -0
  54. package/dist/cjs/ui/ConfigPanel/types.js +15 -0
  55. package/dist/cjs/ui/ConfigPanel/use-abortable-effect/index.js +56 -0
  56. package/dist/cjs/ui/ConfigPanel/use-state-from-promise/index.js +41 -0
  57. package/dist/cjs/ui/ConfigPanel/utils.js +116 -0
  58. package/dist/cjs/ui/SaveIndicator/SaveIndicator.js +79 -0
  59. package/dist/cjs/ui/SaveIndicator/messages.js +14 -0
  60. package/dist/cjs/ui/SaveIndicator/types.js +5 -0
  61. package/dist/cjs/utils.js +73 -0
  62. package/dist/es2019/actions.js +203 -0
  63. package/dist/es2019/commands.js +99 -0
  64. package/dist/es2019/context-panel.js +181 -0
  65. package/dist/es2019/extension-api.js +284 -0
  66. package/dist/es2019/index.js +1 -1
  67. package/dist/es2019/plugin-factory.js +26 -0
  68. package/dist/es2019/plugin-key.js +2 -0
  69. package/dist/es2019/plugin.js +138 -0
  70. package/dist/es2019/pm-plugins/keymap.js +15 -0
  71. package/dist/es2019/pm-plugins/macro/actions.js +152 -0
  72. package/dist/es2019/pm-plugins/macro/index.js +36 -0
  73. package/dist/es2019/pm-plugins/macro/plugin-key.js +2 -0
  74. package/dist/es2019/pm-plugins/macro/types.js +1 -0
  75. package/dist/es2019/pm-plugins/main.js +230 -0
  76. package/dist/es2019/pm-plugins/unique-id.js +69 -0
  77. package/dist/es2019/pm-plugins/utils.js +30 -0
  78. package/dist/es2019/reducer.js +11 -0
  79. package/dist/es2019/toolbar.js +236 -0
  80. package/dist/es2019/ui/ConfigPanel/ConfigPanel.js +415 -0
  81. package/dist/es2019/ui/ConfigPanel/ConfigPanelFieldsLoader.js +100 -0
  82. package/dist/es2019/ui/ConfigPanel/ConfigPanelLoader.js +7 -0
  83. package/dist/es2019/ui/ConfigPanel/ErrorMessage/ErrorImage.js +66 -0
  84. package/dist/es2019/ui/ConfigPanel/ErrorMessage/index.js +25 -0
  85. package/dist/es2019/ui/ConfigPanel/FieldMessages.js +101 -0
  86. package/dist/es2019/ui/ConfigPanel/Fields/Boolean.js +138 -0
  87. package/dist/es2019/ui/ConfigPanel/Fields/CheckboxGroup.js +96 -0
  88. package/dist/es2019/ui/ConfigPanel/Fields/ColorPicker.js +411 -0
  89. package/dist/es2019/ui/ConfigPanel/Fields/CustomSelect.js +132 -0
  90. package/dist/es2019/ui/ConfigPanel/Fields/Date.js +50 -0
  91. package/dist/es2019/ui/ConfigPanel/Fields/DateRange.js +139 -0
  92. package/dist/es2019/ui/ConfigPanel/Fields/Enum.js +35 -0
  93. package/dist/es2019/ui/ConfigPanel/Fields/Expand.js +73 -0
  94. package/dist/es2019/ui/ConfigPanel/Fields/Fieldset.js +227 -0
  95. package/dist/es2019/ui/ConfigPanel/Fields/Number.js +61 -0
  96. package/dist/es2019/ui/ConfigPanel/Fields/RadioGroup.js +40 -0
  97. package/dist/es2019/ui/ConfigPanel/Fields/Select.js +50 -0
  98. package/dist/es2019/ui/ConfigPanel/Fields/SelectItem.js +47 -0
  99. package/dist/es2019/ui/ConfigPanel/Fields/String.js +67 -0
  100. package/dist/es2019/ui/ConfigPanel/Fields/TabGroup.js +57 -0
  101. package/dist/es2019/ui/ConfigPanel/Fields/UnhandledType.js +11 -0
  102. package/dist/es2019/ui/ConfigPanel/Fields/UserSelect.js +194 -0
  103. package/dist/es2019/ui/ConfigPanel/Fields/common/RequiredIndicator.js +5 -0
  104. package/dist/es2019/ui/ConfigPanel/FormContent.js +225 -0
  105. package/dist/es2019/ui/ConfigPanel/FormErrorBoundary.js +100 -0
  106. package/dist/es2019/ui/ConfigPanel/Header.js +140 -0
  107. package/dist/es2019/ui/ConfigPanel/LoadingState.js +15 -0
  108. package/dist/es2019/ui/ConfigPanel/NestedForms/RemovableField.js +52 -0
  109. package/dist/es2019/ui/ConfigPanel/constants.js +7 -0
  110. package/dist/es2019/ui/ConfigPanel/index.js +2 -0
  111. package/dist/es2019/ui/ConfigPanel/messages.js +93 -0
  112. package/dist/es2019/ui/ConfigPanel/transformers.js +367 -0
  113. package/dist/es2019/ui/ConfigPanel/types.js +9 -0
  114. package/dist/es2019/ui/ConfigPanel/use-abortable-effect/index.js +46 -0
  115. package/dist/es2019/ui/ConfigPanel/use-state-from-promise/index.js +30 -0
  116. package/dist/es2019/ui/ConfigPanel/utils.js +86 -0
  117. package/dist/es2019/ui/SaveIndicator/SaveIndicator.js +66 -0
  118. package/dist/es2019/ui/SaveIndicator/messages.js +8 -0
  119. package/dist/es2019/ui/SaveIndicator/types.js +1 -0
  120. package/dist/es2019/utils.js +65 -0
  121. package/dist/esm/actions.js +223 -0
  122. package/dist/esm/commands.js +113 -0
  123. package/dist/esm/context-panel.js +261 -0
  124. package/dist/esm/extension-api.js +259 -0
  125. package/dist/esm/index.js +1 -1
  126. package/dist/esm/plugin-factory.js +25 -0
  127. package/dist/esm/plugin-key.js +2 -0
  128. package/dist/esm/plugin.js +140 -0
  129. package/dist/esm/pm-plugins/keymap.js +15 -0
  130. package/dist/esm/pm-plugins/macro/actions.js +179 -0
  131. package/dist/esm/pm-plugins/macro/index.js +42 -0
  132. package/dist/esm/pm-plugins/macro/plugin-key.js +2 -0
  133. package/dist/esm/pm-plugins/macro/types.js +1 -0
  134. package/dist/esm/pm-plugins/main.js +298 -0
  135. package/dist/esm/pm-plugins/unique-id.js +74 -0
  136. package/dist/esm/pm-plugins/utils.js +68 -0
  137. package/dist/esm/reducer.js +11 -0
  138. package/dist/esm/toolbar.js +235 -0
  139. package/dist/esm/ui/ConfigPanel/ConfigPanel.js +465 -0
  140. package/dist/esm/ui/ConfigPanel/ConfigPanelFieldsLoader.js +112 -0
  141. package/dist/esm/ui/ConfigPanel/ConfigPanelLoader.js +11 -0
  142. package/dist/esm/ui/ConfigPanel/ErrorMessage/ErrorImage.js +68 -0
  143. package/dist/esm/ui/ConfigPanel/ErrorMessage/index.js +26 -0
  144. package/dist/esm/ui/ConfigPanel/FieldMessages.js +97 -0
  145. package/dist/esm/ui/ConfigPanel/Fields/Boolean.js +140 -0
  146. package/dist/esm/ui/ConfigPanel/Fields/CheckboxGroup.js +95 -0
  147. package/dist/esm/ui/ConfigPanel/Fields/ColorPicker.js +414 -0
  148. package/dist/esm/ui/ConfigPanel/Fields/CustomSelect.js +182 -0
  149. package/dist/esm/ui/ConfigPanel/Fields/Date.js +48 -0
  150. package/dist/esm/ui/ConfigPanel/Fields/DateRange.js +154 -0
  151. package/dist/esm/ui/ConfigPanel/Fields/Enum.js +34 -0
  152. package/dist/esm/ui/ConfigPanel/Fields/Expand.js +77 -0
  153. package/dist/esm/ui/ConfigPanel/Fields/Fieldset.js +261 -0
  154. package/dist/esm/ui/ConfigPanel/Fields/Number.js +57 -0
  155. package/dist/esm/ui/ConfigPanel/Fields/RadioGroup.js +46 -0
  156. package/dist/esm/ui/ConfigPanel/Fields/Select.js +50 -0
  157. package/dist/esm/ui/ConfigPanel/Fields/SelectItem.js +45 -0
  158. package/dist/esm/ui/ConfigPanel/Fields/String.js +65 -0
  159. package/dist/esm/ui/ConfigPanel/Fields/TabGroup.js +62 -0
  160. package/dist/esm/ui/ConfigPanel/Fields/UnhandledType.js +10 -0
  161. package/dist/esm/ui/ConfigPanel/Fields/UserSelect.js +258 -0
  162. package/dist/esm/ui/ConfigPanel/Fields/common/RequiredIndicator.js +5 -0
  163. package/dist/esm/ui/ConfigPanel/FormContent.js +223 -0
  164. package/dist/esm/ui/ConfigPanel/FormErrorBoundary.js +133 -0
  165. package/dist/esm/ui/ConfigPanel/Header.js +140 -0
  166. package/dist/esm/ui/ConfigPanel/LoadingState.js +17 -0
  167. package/dist/esm/ui/ConfigPanel/NestedForms/RemovableField.js +53 -0
  168. package/dist/esm/ui/ConfigPanel/constants.js +7 -0
  169. package/dist/esm/ui/ConfigPanel/index.js +2 -0
  170. package/dist/esm/ui/ConfigPanel/messages.js +93 -0
  171. package/dist/esm/ui/ConfigPanel/transformers.js +624 -0
  172. package/dist/esm/ui/ConfigPanel/types.js +9 -0
  173. package/dist/esm/ui/ConfigPanel/use-abortable-effect/index.js +49 -0
  174. package/dist/esm/ui/ConfigPanel/use-state-from-promise/index.js +34 -0
  175. package/dist/esm/ui/ConfigPanel/utils.js +109 -0
  176. package/dist/esm/ui/SaveIndicator/SaveIndicator.js +72 -0
  177. package/dist/esm/ui/SaveIndicator/messages.js +8 -0
  178. package/dist/esm/ui/SaveIndicator/types.js +1 -0
  179. package/dist/esm/utils.js +67 -0
  180. package/dist/types/actions.d.ts +20 -0
  181. package/dist/types/commands.d.ts +15 -0
  182. package/dist/types/context-panel.d.ts +10 -0
  183. package/dist/types/extension-api.d.ts +12 -0
  184. package/dist/types/index.d.ts +2 -1
  185. package/dist/types/plugin-factory.d.ts +4 -0
  186. package/dist/types/plugin-key.d.ts +3 -0
  187. package/dist/types/plugin.d.ts +2 -0
  188. package/dist/types/pm-plugins/keymap.d.ts +3 -0
  189. package/dist/types/pm-plugins/macro/actions.d.ts +9 -0
  190. package/dist/types/pm-plugins/macro/index.d.ts +8 -0
  191. package/dist/types/pm-plugins/macro/plugin-key.d.ts +3 -0
  192. package/dist/types/pm-plugins/macro/types.d.ts +4 -0
  193. package/dist/types/pm-plugins/main.d.ts +25 -0
  194. package/dist/types/pm-plugins/unique-id.d.ts +3 -0
  195. package/dist/types/pm-plugins/utils.d.ts +3 -0
  196. package/dist/types/reducer.d.ts +2 -0
  197. package/dist/types/toolbar.d.ts +44 -0
  198. package/dist/types/types.d.ts +27 -2
  199. package/dist/types/ui/ConfigPanel/ConfigPanel.d.ts +22 -0
  200. package/dist/types/ui/ConfigPanel/ConfigPanelFieldsLoader.d.ts +21 -0
  201. package/dist/types/ui/ConfigPanel/ConfigPanelLoader.d.ts +5 -0
  202. package/dist/types/ui/ConfigPanel/ErrorMessage/ErrorImage.d.ts +4 -0
  203. package/dist/types/ui/ConfigPanel/ErrorMessage/index.d.ts +10 -0
  204. package/dist/types/ui/ConfigPanel/FieldMessages.d.ts +12 -0
  205. package/dist/types/ui/ConfigPanel/Fields/Boolean.d.ts +8 -0
  206. package/dist/types/ui/ConfigPanel/Fields/CheckboxGroup.d.ts +8 -0
  207. package/dist/types/ui/ConfigPanel/Fields/ColorPicker.d.ts +20 -0
  208. package/dist/types/ui/ConfigPanel/Fields/CustomSelect.d.ts +24 -0
  209. package/dist/types/ui/ConfigPanel/Fields/Date.d.ts +20 -0
  210. package/dist/types/ui/ConfigPanel/Fields/DateRange.d.ts +20 -0
  211. package/dist/types/ui/ConfigPanel/Fields/Enum.d.ts +10 -0
  212. package/dist/types/ui/ConfigPanel/Fields/Expand.d.ts +16 -0
  213. package/dist/types/ui/ConfigPanel/Fields/Fieldset.d.ts +19 -0
  214. package/dist/types/ui/ConfigPanel/Fields/Number.d.ts +10 -0
  215. package/dist/types/ui/ConfigPanel/Fields/RadioGroup.d.ts +8 -0
  216. package/dist/types/ui/ConfigPanel/Fields/Select.d.ts +11 -0
  217. package/dist/types/ui/ConfigPanel/Fields/SelectItem.d.ts +5 -0
  218. package/dist/types/ui/ConfigPanel/Fields/String.d.ts +10 -0
  219. package/dist/types/ui/ConfigPanel/Fields/TabGroup.d.ts +14 -0
  220. package/dist/types/ui/ConfigPanel/Fields/UnhandledType.d.ts +6 -0
  221. package/dist/types/ui/ConfigPanel/Fields/UserSelect.d.ts +10 -0
  222. package/dist/types/ui/ConfigPanel/Fields/common/RequiredIndicator.d.ts +1 -0
  223. package/dist/types/ui/ConfigPanel/FormContent.d.ts +4 -0
  224. package/dist/types/ui/ConfigPanel/FormErrorBoundary.d.ts +16 -0
  225. package/dist/types/ui/ConfigPanel/Header.d.ts +23 -0
  226. package/dist/types/ui/ConfigPanel/LoadingState.d.ts +4 -0
  227. package/dist/types/ui/ConfigPanel/NestedForms/RemovableField.d.ts +19 -0
  228. package/dist/types/ui/ConfigPanel/constants.d.ts +2 -0
  229. package/dist/types/ui/ConfigPanel/index.d.ts +2 -0
  230. package/dist/types/ui/ConfigPanel/messages.d.ts +92 -0
  231. package/dist/types/ui/ConfigPanel/transformers.d.ts +9 -0
  232. package/dist/types/ui/ConfigPanel/types.d.ts +36 -0
  233. package/dist/types/ui/ConfigPanel/use-abortable-effect/index.d.ts +16 -0
  234. package/dist/types/ui/ConfigPanel/use-state-from-promise/index.d.ts +15 -0
  235. package/dist/types/ui/ConfigPanel/utils.d.ts +16 -0
  236. package/dist/types/ui/SaveIndicator/SaveIndicator.d.ts +4 -0
  237. package/dist/types/ui/SaveIndicator/messages.d.ts +7 -0
  238. package/dist/types/ui/SaveIndicator/types.d.ts +11 -0
  239. package/dist/types/utils.d.ts +15 -0
  240. package/dist/types-ts4.5/actions.d.ts +20 -0
  241. package/dist/types-ts4.5/commands.d.ts +15 -0
  242. package/dist/types-ts4.5/context-panel.d.ts +10 -0
  243. package/dist/types-ts4.5/extension-api.d.ts +12 -0
  244. package/dist/types-ts4.5/index.d.ts +2 -1
  245. package/dist/types-ts4.5/plugin-factory.d.ts +4 -0
  246. package/dist/types-ts4.5/plugin-key.d.ts +3 -0
  247. package/dist/types-ts4.5/plugin.d.ts +2 -0
  248. package/dist/types-ts4.5/pm-plugins/keymap.d.ts +3 -0
  249. package/dist/types-ts4.5/pm-plugins/macro/actions.d.ts +9 -0
  250. package/dist/types-ts4.5/pm-plugins/macro/index.d.ts +8 -0
  251. package/dist/types-ts4.5/pm-plugins/macro/plugin-key.d.ts +3 -0
  252. package/dist/types-ts4.5/pm-plugins/macro/types.d.ts +4 -0
  253. package/dist/types-ts4.5/pm-plugins/main.d.ts +25 -0
  254. package/dist/types-ts4.5/pm-plugins/unique-id.d.ts +3 -0
  255. package/dist/types-ts4.5/pm-plugins/utils.d.ts +3 -0
  256. package/dist/types-ts4.5/reducer.d.ts +2 -0
  257. package/dist/types-ts4.5/toolbar.d.ts +44 -0
  258. package/dist/types-ts4.5/types.d.ts +27 -2
  259. package/dist/types-ts4.5/ui/ConfigPanel/ConfigPanel.d.ts +22 -0
  260. package/dist/types-ts4.5/ui/ConfigPanel/ConfigPanelFieldsLoader.d.ts +21 -0
  261. package/dist/types-ts4.5/ui/ConfigPanel/ConfigPanelLoader.d.ts +5 -0
  262. package/dist/types-ts4.5/ui/ConfigPanel/ErrorMessage/ErrorImage.d.ts +4 -0
  263. package/dist/types-ts4.5/ui/ConfigPanel/ErrorMessage/index.d.ts +10 -0
  264. package/dist/types-ts4.5/ui/ConfigPanel/FieldMessages.d.ts +12 -0
  265. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Boolean.d.ts +8 -0
  266. package/dist/types-ts4.5/ui/ConfigPanel/Fields/CheckboxGroup.d.ts +8 -0
  267. package/dist/types-ts4.5/ui/ConfigPanel/Fields/ColorPicker.d.ts +20 -0
  268. package/dist/types-ts4.5/ui/ConfigPanel/Fields/CustomSelect.d.ts +24 -0
  269. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Date.d.ts +20 -0
  270. package/dist/types-ts4.5/ui/ConfigPanel/Fields/DateRange.d.ts +20 -0
  271. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Enum.d.ts +10 -0
  272. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Expand.d.ts +16 -0
  273. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Fieldset.d.ts +19 -0
  274. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Number.d.ts +10 -0
  275. package/dist/types-ts4.5/ui/ConfigPanel/Fields/RadioGroup.d.ts +8 -0
  276. package/dist/types-ts4.5/ui/ConfigPanel/Fields/Select.d.ts +11 -0
  277. package/dist/types-ts4.5/ui/ConfigPanel/Fields/SelectItem.d.ts +5 -0
  278. package/dist/types-ts4.5/ui/ConfigPanel/Fields/String.d.ts +10 -0
  279. package/dist/types-ts4.5/ui/ConfigPanel/Fields/TabGroup.d.ts +14 -0
  280. package/dist/types-ts4.5/ui/ConfigPanel/Fields/UnhandledType.d.ts +6 -0
  281. package/dist/types-ts4.5/ui/ConfigPanel/Fields/UserSelect.d.ts +10 -0
  282. package/dist/types-ts4.5/ui/ConfigPanel/Fields/common/RequiredIndicator.d.ts +1 -0
  283. package/dist/types-ts4.5/ui/ConfigPanel/FormContent.d.ts +4 -0
  284. package/dist/types-ts4.5/ui/ConfigPanel/FormErrorBoundary.d.ts +16 -0
  285. package/dist/types-ts4.5/ui/ConfigPanel/Header.d.ts +23 -0
  286. package/dist/types-ts4.5/ui/ConfigPanel/LoadingState.d.ts +4 -0
  287. package/dist/types-ts4.5/ui/ConfigPanel/NestedForms/RemovableField.d.ts +19 -0
  288. package/dist/types-ts4.5/ui/ConfigPanel/constants.d.ts +2 -0
  289. package/dist/types-ts4.5/ui/ConfigPanel/index.d.ts +2 -0
  290. package/dist/types-ts4.5/ui/ConfigPanel/messages.d.ts +92 -0
  291. package/dist/types-ts4.5/ui/ConfigPanel/transformers.d.ts +9 -0
  292. package/dist/types-ts4.5/ui/ConfigPanel/types.d.ts +39 -0
  293. package/dist/types-ts4.5/ui/ConfigPanel/use-abortable-effect/index.d.ts +16 -0
  294. package/dist/types-ts4.5/ui/ConfigPanel/use-state-from-promise/index.d.ts +18 -0
  295. package/dist/types-ts4.5/ui/ConfigPanel/utils.d.ts +16 -0
  296. package/dist/types-ts4.5/ui/SaveIndicator/SaveIndicator.d.ts +4 -0
  297. package/dist/types-ts4.5/ui/SaveIndicator/messages.d.ts +7 -0
  298. package/dist/types-ts4.5/ui/SaveIndicator/types.d.ts +11 -0
  299. package/dist/types-ts4.5/utils.d.ts +15 -0
  300. package/example-utils/config-panel/ConfigPanelWithExtensionPicker.tsx +217 -0
  301. package/example-utils/config-panel/ConfigPanelWithProviders.tsx +51 -0
  302. package/example-utils/config-panel/ExtensionNodePicker.tsx +141 -0
  303. package/example-utils/config-panel/FieldTypePicker.tsx +63 -0
  304. package/example-utils/config-panel/example-manifest-all-fields.ts +86 -0
  305. package/example-utils/config-panel/example-manifest-individual-fields.ts +85 -0
  306. package/example-utils/config-panel/fields.ts +611 -0
  307. package/package.json +49 -7
@@ -0,0 +1,133 @@
1
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/createClass";
4
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
5
+ import _inherits from "@babel/runtime/helpers/inherits";
6
+ import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
7
+ import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
8
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
9
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
10
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
11
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
12
+ import React from 'react';
13
+ import { injectIntl } from 'react-intl-next';
14
+ import { withAnalyticsContext, withAnalyticsEvents } from '@atlaskit/analytics-next';
15
+ import { ACTION, ACTION_SUBJECT, editorAnalyticsChannel, EVENT_TYPE } from '@atlaskit/editor-common/analytics';
16
+ import SectionMessage from '@atlaskit/section-message';
17
+ import { messages } from './messages';
18
+ // eslint-disable-next-line @repo/internal/react/no-class-components
19
+ var FormErrorBoundaryInner = /*#__PURE__*/function (_React$Component) {
20
+ _inherits(FormErrorBoundaryInner, _React$Component);
21
+ var _super = _createSuper(FormErrorBoundaryInner);
22
+ function FormErrorBoundaryInner() {
23
+ var _this;
24
+ _classCallCheck(this, FormErrorBoundaryInner);
25
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
26
+ args[_key] = arguments[_key];
27
+ }
28
+ _this = _super.call.apply(_super, [this].concat(args));
29
+ _defineProperty(_assertThisInitialized(_this), "state", {
30
+ error: undefined
31
+ });
32
+ _defineProperty(_assertThisInitialized(_this), "getProductName", /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
33
+ var contextIdentifierProvider, context;
34
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
35
+ while (1) switch (_context.prev = _context.next) {
36
+ case 0:
37
+ contextIdentifierProvider = _this.props.contextIdentifierProvider;
38
+ if (!contextIdentifierProvider) {
39
+ _context.next = 7;
40
+ break;
41
+ }
42
+ _context.next = 4;
43
+ return contextIdentifierProvider;
44
+ case 4:
45
+ context = _context.sent;
46
+ if (!context.product) {
47
+ _context.next = 7;
48
+ break;
49
+ }
50
+ return _context.abrupt("return", context.product);
51
+ case 7:
52
+ return _context.abrupt("return", 'atlaskit');
53
+ case 8:
54
+ case "end":
55
+ return _context.stop();
56
+ }
57
+ }, _callee);
58
+ })));
59
+ _defineProperty(_assertThisInitialized(_this), "fireAnalytics", function (analyticsErrorPayload) {
60
+ var _this$props = _this.props,
61
+ createAnalyticsEvent = _this$props.createAnalyticsEvent,
62
+ extensionKey = _this$props.extensionKey,
63
+ fields = _this$props.fields;
64
+ _this.getProductName().then(function (product) {
65
+ var _window;
66
+ if (!createAnalyticsEvent) {
67
+ // eslint-disable-next-line no-console
68
+ console.error('ConfigPanel FormErrorBoundary: Missing `createAnalyticsEvent`', {
69
+ channel: editorAnalyticsChannel,
70
+ product: product,
71
+ error: analyticsErrorPayload
72
+ });
73
+ return;
74
+ }
75
+ var error = analyticsErrorPayload.error,
76
+ errorInfo = analyticsErrorPayload.errorInfo,
77
+ errorStack = analyticsErrorPayload.errorStack;
78
+ var payload = {
79
+ action: ACTION.ERRORED,
80
+ actionSubject: ACTION_SUBJECT.CONFIG_PANEL,
81
+ eventType: EVENT_TYPE.UI,
82
+ attributes: {
83
+ product: product,
84
+ browserInfo: ((_window = window) === null || _window === void 0 || (_window = _window.navigator) === null || _window === void 0 ? void 0 : _window.userAgent) || 'unknown',
85
+ extensionKey: extensionKey,
86
+ fields: JSON.stringify(fields),
87
+ error: error,
88
+ errorInfo: errorInfo,
89
+ errorStack: errorStack
90
+ }
91
+ };
92
+ createAnalyticsEvent(payload).fire(editorAnalyticsChannel);
93
+ }).catch(function (e) {
94
+ // eslint-disable-next-line no-console
95
+ console.error('Failed to resolve product name from contextIdentifierProvider.', e);
96
+ });
97
+ });
98
+ return _this;
99
+ }
100
+ _createClass(FormErrorBoundaryInner, [{
101
+ key: "componentDidCatch",
102
+ value: function componentDidCatch(error, errorInfo) {
103
+ var _this2 = this;
104
+ this.setState({
105
+ error: error
106
+ }, function () {
107
+ // Log the error
108
+ _this2.fireAnalytics({
109
+ error: error.toString(),
110
+ errorInfo: errorInfo,
111
+ errorStack: error.stack
112
+ });
113
+ });
114
+ }
115
+ }, {
116
+ key: "render",
117
+ value: function render() {
118
+ var intl = this.props.intl;
119
+ var error = this.state.error;
120
+ if (!error) {
121
+ return this.props.children;
122
+ }
123
+ return /*#__PURE__*/React.createElement(SectionMessage, {
124
+ title: intl.formatMessage(messages.errorBoundaryTitle),
125
+ appearance: "error"
126
+ }, /*#__PURE__*/React.createElement("p", null, /*#__PURE__*/React.createElement("i", null, error.message)), /*#__PURE__*/React.createElement("p", null, intl.formatMessage(messages.errorBoundaryNote)));
127
+ }
128
+ }]);
129
+ return FormErrorBoundaryInner;
130
+ }(React.Component);
131
+ export var FormErrorBoundaryImpl = injectIntl(FormErrorBoundaryInner);
132
+ export var FormErrorBoundary = withAnalyticsContext()(withAnalyticsEvents()(FormErrorBoundaryImpl));
133
+ FormErrorBoundary.displayName = 'FormErrorBoundary';
@@ -0,0 +1,140 @@
1
+ /** @jsx jsx */
2
+ import { Fragment } from 'react';
3
+ import { css, jsx } from '@emotion/react';
4
+ import { injectIntl } from 'react-intl-next';
5
+ import Loadable from 'react-loadable';
6
+ import Button from '@atlaskit/button/custom-theme-button';
7
+ import { relativeFontSizeToBase16 } from '@atlaskit/editor-shared-styles';
8
+ import CrossIcon from '@atlaskit/icon/glyph/cross';
9
+ import { N200 } from '@atlaskit/theme/colors';
10
+ import { borderRadius } from '@atlaskit/theme/constants';
11
+ import { messages } from './messages';
12
+ var iconWidth = 40;
13
+ var buttonWidth = 40;
14
+ var margin = 16;
15
+ var gapSizeForEllipsis = iconWidth + buttonWidth + margin * 2;
16
+ var itemStyles = css({
17
+ display: 'flex',
18
+ marginBottom: "var(--ds-space-300, 24px)"
19
+ });
20
+ var itemIconStyles = css({
21
+ width: iconWidth,
22
+ height: iconWidth,
23
+ overflow: 'hidden',
24
+ border: "1px solid ".concat("var(--ds-border, rgba(223, 225, 229, 0.5))"),
25
+ borderRadius: "".concat(borderRadius(), "px"),
26
+ boxSizing: 'border-box',
27
+ display: 'flex',
28
+ justifyContent: 'center',
29
+ alignItems: 'center',
30
+ // eslint-disable-next-line @atlaskit/design-system/no-nested-styles
31
+ div: {
32
+ width: iconWidth,
33
+ height: iconWidth
34
+ }
35
+ });
36
+ var itemBodyStyles = css({
37
+ display: 'flex',
38
+ flexDirection: 'row',
39
+ flexWrap: 'nowrap',
40
+ justifyContent: 'space-between',
41
+ lineHeight: 1.4,
42
+ margin: "0 ".concat("var(--ds-space-200, 16px)"),
43
+ flexGrow: 3,
44
+ maxWidth: "calc(100% - ".concat(gapSizeForEllipsis, "px)")
45
+ });
46
+ var centeredItemTitleStyles = css({
47
+ display: 'flex',
48
+ flexDirection: 'column',
49
+ justifyContent: 'center'
50
+ });
51
+ var itemTextStyles = css({
52
+ maxWidth: '100%',
53
+ whiteSpace: 'initial',
54
+ // eslint-disable-next-line @atlaskit/design-system/no-nested-styles
55
+ itemSummary: {
56
+ fontSize: relativeFontSizeToBase16(11.67),
57
+ color: "var(--ds-text-subtlest, ".concat(N200, ")"),
58
+ marginTop: "var(--ds-space-050, 4px)",
59
+ whiteSpace: 'nowrap',
60
+ overflow: 'hidden',
61
+ textOverflow: 'ellipsis'
62
+ }
63
+ });
64
+ var descriptionStyles = css({
65
+ marginBottom: "var(--ds-space-300, 24px)"
66
+ });
67
+ var helpLinkStyles = css({
68
+ paddingTop: "var(--ds-space-150, 12px)"
69
+ });
70
+ var closeButtonWrapperStyles = css({
71
+ width: buttonWidth,
72
+ textAlign: 'right'
73
+ });
74
+ var Header = function Header(_ref) {
75
+ var icon = _ref.icon,
76
+ title = _ref.title,
77
+ description = _ref.description,
78
+ summary = _ref.summary,
79
+ documentationUrl = _ref.documentationUrl,
80
+ enableHelpCTA = _ref.enableHelpCTA,
81
+ onClose = _ref.onClose,
82
+ intl = _ref.intl;
83
+ var ResolvedIcon = Loadable({
84
+ loader: icon,
85
+ loading: function loading() {
86
+ return null;
87
+ }
88
+ });
89
+ return jsx(Fragment, null, jsx("div", {
90
+ css: itemStyles
91
+ }, jsx("div", {
92
+ css: itemIconStyles
93
+ }, jsx(ResolvedIcon, {
94
+ label: title
95
+ })), jsx("div", {
96
+ css: itemBodyStyles
97
+ }, summary ? jsx("div", {
98
+ css: itemTextStyles
99
+ }, jsx("div", {
100
+ className: "item-title",
101
+ id: "context-panel-title",
102
+ "data-testId": "context-panel-title"
103
+ }, title), jsx("div", {
104
+ className: "item-summary"
105
+ }, summary)) : jsx("div", {
106
+ css: centeredItemTitleStyles,
107
+ id: "context-panel-title",
108
+ "data-testId": "context-panel-title"
109
+ }, title)), jsx("div", {
110
+ css: closeButtonWrapperStyles
111
+ }, jsx(Button, {
112
+ appearance: "subtle",
113
+ iconBefore: jsx(CrossIcon, {
114
+ label: intl.formatMessage(messages.close)
115
+ }),
116
+ onClick: onClose
117
+ }))), (description || documentationUrl) && jsx("p", {
118
+ css: descriptionStyles,
119
+ "data-testid": "config-panel-header-description"
120
+ }, description && jsx(Fragment, null, description.replace(/([^.])$/, '$1.'), " "), documentationUrl && (enableHelpCTA ? jsx("p", {
121
+ css: helpLinkStyles
122
+ }, jsx(HelpLink, {
123
+ documentationUrl: documentationUrl,
124
+ label: intl.formatMessage(messages.help)
125
+ })) : jsx(HelpLink, {
126
+ documentationUrl: documentationUrl,
127
+ label: intl.formatMessage(messages.documentation)
128
+ }))));
129
+ };
130
+ var HelpLink = function HelpLink(_ref2) {
131
+ var documentationUrl = _ref2.documentationUrl,
132
+ label = _ref2.label;
133
+ return jsx("a", {
134
+ target: "_blank",
135
+ rel: "noopener noreferrer",
136
+ href: documentationUrl,
137
+ "data-testid": "config-panel-header-documentation-link"
138
+ }, label);
139
+ };
140
+ export default injectIntl(Header);
@@ -0,0 +1,17 @@
1
+ /** @jsx jsx */
2
+ import { css, jsx } from '@emotion/react';
3
+ import Spinner from '@atlaskit/spinner';
4
+ var spinnerWrapperStyles = css({
5
+ display: 'flex',
6
+ justifyContent: 'center',
7
+ marginTop: "var(--ds-space-800, 64px)"
8
+ });
9
+ var LoadingState = function LoadingState() {
10
+ return jsx("div", {
11
+ css: spinnerWrapperStyles,
12
+ "data-testid": "ConfigPanelLoading"
13
+ }, jsx(Spinner, {
14
+ size: "small"
15
+ }));
16
+ };
17
+ export default LoadingState;
@@ -0,0 +1,53 @@
1
+ /** @jsx jsx */
2
+ import React from 'react';
3
+ import { css, jsx } from '@emotion/react';
4
+ import { injectIntl } from 'react-intl-next';
5
+ import CrossCircleIcon from '@atlaskit/icon/glyph/cross-circle';
6
+ import { N80, R300 } from '@atlaskit/theme/colors';
7
+ import Tooltip from '@atlaskit/tooltip';
8
+ import { messages } from '../messages';
9
+ var removableFieldWrapperStyles = css({
10
+ position: 'relative',
11
+ marginBottom: 0
12
+ });
13
+ var wrapperWithMarginBottomStyles = css({
14
+ marginBottom: "var(--ds-space-200, 16px)"
15
+ });
16
+ var removeButtonWrapperStyles = css({
17
+ position: 'absolute',
18
+ right: 0,
19
+ top: 0,
20
+ cursor: 'pointer',
21
+ color: "var(--ds-icon-subtle, ".concat(N80, ")"),
22
+ '&:hover': {
23
+ color: "var(--ds-icon-danger, ".concat(R300, ")")
24
+ }
25
+ });
26
+ var RemovableField = function RemovableField(_ref) {
27
+ var _children$props$field;
28
+ var name = _ref.name,
29
+ canRemoveField = _ref.canRemoveField,
30
+ onClickRemove = _ref.onClickRemove,
31
+ children = _ref.children,
32
+ intl = _ref.intl,
33
+ className = _ref.className;
34
+ var onClickCallback = React.useCallback(function () {
35
+ return onClickRemove && onClickRemove(name);
36
+ }, [name, onClickRemove]);
37
+ var hasMarginBottom = ((_children$props$field = children.props.field) === null || _children$props$field === void 0 ? void 0 : _children$props$field.type) !== 'expand';
38
+ return jsx("div", {
39
+ css: [removableFieldWrapperStyles, hasMarginBottom && wrapperWithMarginBottomStyles],
40
+ className: className
41
+ }, children, canRemoveField && jsx("div", {
42
+ css: removeButtonWrapperStyles,
43
+ "data-testid": "remove-field-".concat(name),
44
+ onClick: onClickCallback
45
+ }, jsx(Tooltip, {
46
+ content: intl.formatMessage(messages.removeField),
47
+ position: "left"
48
+ }, jsx(CrossCircleIcon, {
49
+ size: "small",
50
+ label: intl.formatMessage(messages.removeField)
51
+ }))));
52
+ };
53
+ export default injectIntl(RemovableField);
@@ -0,0 +1,7 @@
1
+ // Allowlist of { macroKey: parameterName[] } for analytics logging
2
+ export var ALLOWED_LOGGED_MACRO_PARAMS = {
3
+ children: ['all', 'first', 'depth', 'style', 'excerptType', 'sort', 'reverse'],
4
+ 'recently-updated': ['width', 'types', 'max', 'theme', 'showProfilePic', 'hideHeading'],
5
+ excerpt: ['hidden']
6
+ };
7
+ export var ALLOWED_PARAM_TYPES = ['enum', 'number', 'boolean'];
@@ -0,0 +1,2 @@
1
+ import ConfigPanelLoader from './ConfigPanelLoader';
2
+ export default ConfigPanelLoader;
@@ -0,0 +1,93 @@
1
+ import { defineMessages } from 'react-intl-next';
2
+ export var messages = defineMessages({
3
+ submit: {
4
+ id: 'fabric.editor.configPanel.submit',
5
+ defaultMessage: 'Submit',
6
+ description: 'Submit button label'
7
+ },
8
+ cancel: {
9
+ id: 'fabric.editor.configPanel.cancel',
10
+ defaultMessage: 'Cancel',
11
+ description: 'Cancel button label'
12
+ },
13
+ close: {
14
+ id: 'fabric.editor.configPanel.close',
15
+ defaultMessage: 'Close',
16
+ description: 'Close button label'
17
+ },
18
+ required: {
19
+ id: 'fabric.editor.configPanel.required',
20
+ defaultMessage: 'Required field',
21
+ description: 'Validation message for required field'
22
+ },
23
+ invalid: {
24
+ id: 'fabric.editor.configPanel.invalid',
25
+ defaultMessage: 'Invalid field',
26
+ description: 'Validation message when a field value is not acceptable'
27
+ },
28
+ isMultipleAndRadio: {
29
+ id: 'fabric.editor.configPanel.fieldTypeError.isMultipleAndRadio',
30
+ defaultMessage: 'Can not combine isMultiple with style: radio',
31
+ description: 'Configuration error'
32
+ },
33
+ addField: {
34
+ id: 'fabric.editor.configPanel.formType.addField',
35
+ defaultMessage: 'Add field',
36
+ description: 'Button to add a new field in nested forms'
37
+ },
38
+ removeField: {
39
+ id: 'fabric.editor.configPanel.formType.removeField',
40
+ defaultMessage: 'Remove field',
41
+ description: 'Button to remove a field in nested forms'
42
+ },
43
+ createOption: {
44
+ id: 'fabric.editor.configPanel.customSelect.createOption',
45
+ defaultMessage: 'Create',
46
+ description: 'Create a new option for a select field'
47
+ },
48
+ documentation: {
49
+ id: 'fabric.editor.configPanel.documentation',
50
+ defaultMessage: 'Documentation',
51
+ description: 'Label for the documentation link'
52
+ },
53
+ help: {
54
+ id: 'fabric.editor.configPanel.help',
55
+ defaultMessage: 'Need help?',
56
+ description: 'Label for documentation link v.2 (to replace "Documentation" text)'
57
+ },
58
+ custom: {
59
+ id: 'fabric.editor.configPanel.dateRange.option.custom',
60
+ defaultMessage: 'Custom',
61
+ description: 'Label for the option "Custom" in the date range UI element'
62
+ },
63
+ from: {
64
+ id: 'fabric.editor.configPanel.dateRange.custom.from',
65
+ defaultMessage: 'From',
66
+ description: 'Label for the initial date when the option "Custom" is selected in the date range UI element'
67
+ },
68
+ to: {
69
+ id: 'fabric.editor.configPanel.dateRange.custom.to',
70
+ defaultMessage: 'To',
71
+ description: 'Label for the end date when the option "Custom" is selected in the date range UI element'
72
+ },
73
+ expand: {
74
+ id: 'fabric.editor.configPanel.dateRange.grouping.expand',
75
+ defaultMessage: 'Expand',
76
+ description: 'Label for expanding a group of fields'
77
+ },
78
+ collapse: {
79
+ id: 'fabric.editor.configPanel.dateRange.grouping.collapse',
80
+ defaultMessage: 'Collapse',
81
+ description: 'Label for collapsing a group of fields'
82
+ },
83
+ errorBoundaryTitle: {
84
+ id: 'fabric.editor.configPanel.errorBoundary.title',
85
+ defaultMessage: 'Something went wrong.',
86
+ description: 'Title for uncaught config panel error'
87
+ },
88
+ errorBoundaryNote: {
89
+ id: 'fabric.editor.configPanel.errorBoundary.note',
90
+ defaultMessage: "We've let the team know. You can still edit and publish this page, or check the error console for more information.",
91
+ description: 'Note for uncaught config panel error'
92
+ }
93
+ });