@lblod/ember-rdfa-editor 12.8.0 → 12.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (322) hide show
  1. package/declarations/components/_private/attribute-editor/index.d.ts +2 -2
  2. package/declarations/components/_private/attribute-editor/index.d.ts.map +1 -1
  3. package/declarations/components/_private/common/configurable-rdfa-display.d.ts.map +1 -0
  4. package/declarations/components/_private/common/object-term-schemas.d.ts.map +1 -0
  5. package/declarations/components/_private/common/property-details.d.ts.map +1 -0
  6. package/declarations/components/_private/common/selection-tooltip.d.ts.map +1 -0
  7. package/declarations/components/_private/common/types.d.ts +17 -0
  8. package/declarations/components/_private/common/types.d.ts.map +1 -0
  9. package/declarations/components/_private/debug-info/index.d.ts.map +1 -1
  10. package/declarations/components/_private/doc-editor/info-pill.d.ts +0 -2
  11. package/declarations/components/_private/doc-editor/info-pill.d.ts.map +1 -1
  12. package/declarations/components/_private/doc-imported-resource-editor/card.d.ts +56 -0
  13. package/declarations/components/_private/doc-imported-resource-editor/card.d.ts.map +1 -0
  14. package/declarations/components/_private/{rdfa-editor/doc-imported-resource-editor → doc-imported-resource-editor}/form.d.ts +1 -1
  15. package/declarations/components/_private/doc-imported-resource-editor/form.d.ts.map +1 -0
  16. package/declarations/components/_private/{rdfa-editor/external-triple-editor/index.d.ts → external-triple-editor/card.d.ts} +7 -3
  17. package/declarations/components/_private/external-triple-editor/card.d.ts.map +1 -0
  18. package/declarations/components/_private/external-triple-editor/form.d.ts.map +1 -0
  19. package/declarations/components/_private/imported-resource-linker/card.d.ts +22 -0
  20. package/declarations/components/_private/imported-resource-linker/card.d.ts.map +1 -0
  21. package/declarations/components/_private/node-controls/card.d.ts +17 -0
  22. package/declarations/components/_private/node-controls/card.d.ts.map +1 -0
  23. package/declarations/components/_private/{rdfa-editor/remove-node/index.d.ts → node-controls/remove-node.d.ts} +2 -2
  24. package/declarations/components/_private/node-controls/remove-node.d.ts.map +1 -0
  25. package/declarations/components/_private/{rdfa-editor/wrapping-utils/index.d.ts → node-controls/wrapping-utils.d.ts} +4 -7
  26. package/declarations/components/_private/node-controls/wrapping-utils.d.ts.map +1 -0
  27. package/declarations/components/_private/rdfa-visualiser/rdfa-explorer.d.ts +0 -2
  28. package/declarations/components/_private/rdfa-visualiser/rdfa-explorer.d.ts.map +1 -1
  29. package/declarations/components/_private/rdfa-visualiser/visualiser-card.d.ts +0 -2
  30. package/declarations/components/_private/rdfa-visualiser/visualiser-card.d.ts.map +1 -1
  31. package/declarations/components/_private/relationship-editor/card.d.ts +56 -0
  32. package/declarations/components/_private/relationship-editor/card.d.ts.map +1 -0
  33. package/declarations/components/_private/relationship-editor/configs.d.ts +8 -0
  34. package/declarations/components/_private/relationship-editor/configs.d.ts.map +1 -0
  35. package/declarations/components/_private/relationship-editor/create-button.d.ts +28 -0
  36. package/declarations/components/_private/relationship-editor/create-button.d.ts.map +1 -0
  37. package/declarations/components/_private/relationship-editor/modals/classic.d.ts +37 -0
  38. package/declarations/components/_private/relationship-editor/modals/classic.d.ts.map +1 -0
  39. package/declarations/components/_private/relationship-editor/modals/dev-mode.d.ts +65 -0
  40. package/declarations/components/_private/relationship-editor/modals/dev-mode.d.ts.map +1 -0
  41. package/declarations/components/_private/relationship-editor/types.d.ts +48 -0
  42. package/declarations/components/_private/relationship-editor/types.d.ts.map +1 -0
  43. package/declarations/components/_private/{number-editor/index.d.ts → utils/number-editor.d.ts} +1 -1
  44. package/declarations/components/_private/utils/number-editor.d.ts.map +1 -0
  45. package/declarations/components/_private/utils/with-unique-id.d.ts.map +1 -0
  46. package/declarations/components/au-native-toggle.d.ts +15 -1
  47. package/declarations/components/au-native-toggle.d.ts.map +1 -1
  48. package/declarations/components/index.d.ts +1 -1
  49. package/declarations/components/index.d.ts.map +1 -1
  50. package/declarations/components/plugins/table/table-tooltip.d.ts +1 -1
  51. package/declarations/components/plugins/table/table-tooltip.d.ts.map +1 -1
  52. package/declarations/components/plugins/text-style/bold.d.ts +9 -2
  53. package/declarations/components/plugins/text-style/bold.d.ts.map +1 -1
  54. package/declarations/components/plugins/text-style/italic.d.ts +9 -2
  55. package/declarations/components/plugins/text-style/italic.d.ts.map +1 -1
  56. package/declarations/components/plugins/text-style/strikethrough.d.ts +9 -2
  57. package/declarations/components/plugins/text-style/strikethrough.d.ts.map +1 -1
  58. package/declarations/components/plugins/text-style/subscript.d.ts +9 -2
  59. package/declarations/components/plugins/text-style/subscript.d.ts.map +1 -1
  60. package/declarations/components/plugins/text-style/superscript.d.ts +9 -2
  61. package/declarations/components/plugins/text-style/superscript.d.ts.map +1 -1
  62. package/declarations/components/plugins/text-style/underline.d.ts +9 -2
  63. package/declarations/components/plugins/text-style/underline.d.ts.map +1 -1
  64. package/declarations/components/responsive-toolbar.d.ts +15 -11
  65. package/declarations/components/responsive-toolbar.d.ts.map +1 -1
  66. package/declarations/components/toolbar/button.d.ts +17 -12
  67. package/declarations/components/toolbar/button.d.ts.map +1 -1
  68. package/declarations/components/toolbar/divider.d.ts +1 -1
  69. package/declarations/components/toolbar/divider.d.ts.map +1 -1
  70. package/declarations/components/toolbar/dropdown-item.d.ts +10 -4
  71. package/declarations/components/toolbar/dropdown-item.d.ts.map +1 -1
  72. package/declarations/components/toolbar/dropdown.d.ts +19 -8
  73. package/declarations/components/toolbar/dropdown.d.ts.map +1 -1
  74. package/declarations/components/toolbar/group.d.ts +5 -5
  75. package/declarations/components/toolbar/group.d.ts.map +1 -1
  76. package/declarations/components/toolbar/mark.d.ts +11 -7
  77. package/declarations/components/toolbar/mark.d.ts.map +1 -1
  78. package/declarations/components/toolbar/spacer.d.ts +2 -1
  79. package/declarations/components/toolbar/spacer.d.ts.map +1 -1
  80. package/declarations/core/say-data-factory/data-factory.d.ts.map +1 -1
  81. package/declarations/core/say-editor.d.ts.map +1 -1
  82. package/declarations/core/say-node-spec.d.ts +7 -0
  83. package/declarations/core/say-node-spec.d.ts.map +1 -1
  84. package/declarations/nodes/block-rdfa.d.ts +1 -1
  85. package/declarations/plugins/on-changed/plugin.d.ts +9 -0
  86. package/declarations/plugins/on-changed/plugin.d.ts.map +1 -0
  87. package/declarations/utils/_private/datastore/node-map.d.ts +1 -1
  88. package/declarations/utils/_private/ember-node.d.ts +3 -2
  89. package/declarations/utils/_private/ember-node.d.ts.map +1 -1
  90. package/declarations/utils/_private/types.d.ts +1 -0
  91. package/declarations/utils/_private/types.d.ts.map +1 -1
  92. package/declarations/utils/transaction-utils.d.ts +17 -3
  93. package/declarations/utils/transaction-utils.d.ts.map +1 -1
  94. package/dist/_app_/components/_private/{rdfa-editor/backlink-editor/form.js → common/configurable-rdfa-display.js} +1 -1
  95. package/dist/_app_/components/_private/common/object-term-schemas.js +1 -0
  96. package/dist/_app_/components/_private/{rdfa-editor/index.js → common/property-details.js} +1 -1
  97. package/dist/_app_/components/_private/{link-rdfa-node-poc/modal.js → common/selection-tooltip.js} +1 -1
  98. package/dist/_app_/components/_private/{with-unique-id.js → common/types.js} +1 -1
  99. package/dist/_app_/components/_private/doc-imported-resource-editor/card.js +1 -0
  100. package/dist/_app_/components/_private/{rdfa-editor/property-editor → doc-imported-resource-editor}/form.js +1 -1
  101. package/dist/_app_/components/_private/external-triple-editor/card.js +1 -0
  102. package/dist/_app_/components/_private/external-triple-editor/form.js +1 -0
  103. package/dist/_app_/components/_private/imported-resource-linker/card.js +1 -0
  104. package/dist/_app_/components/_private/{rdfa-editor/types.js → node-controls/card.js} +1 -1
  105. package/dist/_app_/components/_private/{link-rdfa-node-poc/button.js → node-controls/remove-node.js} +1 -1
  106. package/dist/_app_/components/_private/node-controls/wrapping-utils.js +1 -0
  107. package/dist/_app_/components/_private/relationship-editor/card.js +1 -0
  108. package/dist/_app_/components/_private/relationship-editor/configs.js +1 -0
  109. package/dist/_app_/components/_private/relationship-editor/create-button.js +1 -0
  110. package/dist/_app_/components/_private/relationship-editor/modals/classic.js +1 -0
  111. package/dist/_app_/components/_private/relationship-editor/modals/dev-mode.js +1 -0
  112. package/dist/_app_/components/_private/relationship-editor/types.js +1 -0
  113. package/dist/_app_/components/_private/{selection-tooltip.js → utils/number-editor.js} +1 -1
  114. package/dist/_app_/components/_private/{number-editor/index.js → utils/with-unique-id.js} +1 -1
  115. package/dist/commands/_private/rdfa-commands/remove-backlink.js +1 -1
  116. package/dist/commands/_private/rdfa-commands/select-node-by-rdfa-id.js +1 -1
  117. package/dist/commands/_private/rdfa-commands/select-node-by-subject.js +1 -1
  118. package/dist/commands/_private/rdfa-commands/wrap-inline-resource.js +1 -1
  119. package/dist/commands/_private/rdfa-commands/wrap-literal.js +1 -1
  120. package/dist/commands/_private/rdfa-commands/wrap-resource.js +1 -1
  121. package/dist/commands/rdfa-commands/add-property.js +1 -1
  122. package/dist/commands/rdfa-commands/remove-property.js +1 -1
  123. package/dist/components/_private/attribute-editor/index.js +10 -10
  124. package/dist/components/_private/attribute-editor/index.js.map +1 -1
  125. package/dist/components/_private/common/configurable-rdfa-display.js.map +1 -0
  126. package/dist/components/_private/common/object-term-schemas.js.map +1 -0
  127. package/dist/components/_private/{rdfa-editor → common}/property-details.js +1 -1
  128. package/dist/components/_private/common/property-details.js.map +1 -0
  129. package/dist/components/_private/{selection-tooltip.js → common/selection-tooltip.js} +1 -1
  130. package/dist/components/_private/common/selection-tooltip.js.map +1 -0
  131. package/dist/components/_private/debug-info/index.js +4 -14
  132. package/dist/components/_private/debug-info/index.js.map +1 -1
  133. package/dist/components/_private/doc-editor/info-pill.js +0 -2
  134. package/dist/components/_private/doc-editor/info-pill.js.map +1 -1
  135. package/dist/components/_private/doc-imported-resource-editor/card.js +265 -0
  136. package/dist/components/_private/doc-imported-resource-editor/card.js.map +1 -0
  137. package/dist/components/_private/{rdfa-editor/doc-imported-resource-editor → doc-imported-resource-editor}/form.js +3 -3
  138. package/dist/components/_private/doc-imported-resource-editor/form.js.map +1 -0
  139. package/dist/components/_private/{rdfa-editor/external-triple-editor/index.js → external-triple-editor/card.js} +81 -72
  140. package/dist/components/_private/external-triple-editor/card.js.map +1 -0
  141. package/dist/components/_private/{rdfa-editor/external-triple-editor → external-triple-editor}/form.js +4 -4
  142. package/dist/components/_private/external-triple-editor/form.js.map +1 -0
  143. package/dist/components/_private/imported-resource-linker/card.js +69 -0
  144. package/dist/components/_private/imported-resource-linker/card.js.map +1 -0
  145. package/dist/components/_private/node-controls/card.js +34 -0
  146. package/dist/components/_private/node-controls/card.js.map +1 -0
  147. package/dist/components/_private/{rdfa-editor/remove-node/index.js → node-controls/remove-node.js} +3 -3
  148. package/dist/components/_private/node-controls/remove-node.js.map +1 -0
  149. package/dist/components/_private/node-controls/wrapping-utils.js +206 -0
  150. package/dist/components/_private/node-controls/wrapping-utils.js.map +1 -0
  151. package/dist/components/_private/rdfa-visualiser/rdfa-explorer.js +1 -1
  152. package/dist/components/_private/rdfa-visualiser/rdfa-explorer.js.map +1 -1
  153. package/dist/components/_private/rdfa-visualiser/resource-info.js +3 -3
  154. package/dist/components/_private/rdfa-visualiser/resource-info.js.map +1 -1
  155. package/dist/components/_private/rdfa-visualiser/visualiser-card.js +3 -15
  156. package/dist/components/_private/rdfa-visualiser/visualiser-card.js.map +1 -1
  157. package/dist/components/_private/relationship-editor/card.js +301 -0
  158. package/dist/components/_private/relationship-editor/card.js.map +1 -0
  159. package/dist/components/_private/relationship-editor/configs.js +155 -0
  160. package/dist/components/_private/relationship-editor/configs.js.map +1 -0
  161. package/dist/components/_private/{link-rdfa-node-poc/button.js → relationship-editor/create-button.js} +27 -11
  162. package/dist/components/_private/relationship-editor/create-button.js.map +1 -0
  163. package/dist/components/_private/relationship-editor/modals/classic.js +126 -0
  164. package/dist/components/_private/relationship-editor/modals/classic.js.map +1 -0
  165. package/dist/components/_private/relationship-editor/modals/dev-mode.js +261 -0
  166. package/dist/components/_private/relationship-editor/modals/dev-mode.js.map +1 -0
  167. package/dist/components/_private/relationship-editor/types.js +2 -0
  168. package/dist/components/_private/relationship-editor/types.js.map +1 -0
  169. package/dist/components/_private/{number-editor/index.js → utils/number-editor.js} +1 -1
  170. package/dist/components/_private/utils/number-editor.js.map +1 -0
  171. package/dist/components/_private/utils/with-unique-id.js.map +1 -0
  172. package/dist/components/au-native-toggle.js +10 -5
  173. package/dist/components/au-native-toggle.js.map +1 -1
  174. package/dist/components/index.js +1 -1
  175. package/dist/components/plugins/list/ordered.js +1 -1
  176. package/dist/components/plugins/list/unordered.js +1 -1
  177. package/dist/components/plugins/table/table-tooltip.js +1 -1
  178. package/dist/components/plugins/table/table-tooltip.js.map +1 -1
  179. package/dist/components/plugins/text-style/bold.js +4 -4
  180. package/dist/components/plugins/text-style/bold.js.map +1 -1
  181. package/dist/components/plugins/text-style/italic.js +4 -4
  182. package/dist/components/plugins/text-style/italic.js.map +1 -1
  183. package/dist/components/plugins/text-style/strikethrough.js +4 -4
  184. package/dist/components/plugins/text-style/strikethrough.js.map +1 -1
  185. package/dist/components/plugins/text-style/subscript.js +4 -4
  186. package/dist/components/plugins/text-style/subscript.js.map +1 -1
  187. package/dist/components/plugins/text-style/superscript.js +4 -4
  188. package/dist/components/plugins/text-style/superscript.js.map +1 -1
  189. package/dist/components/plugins/text-style/underline.js +4 -4
  190. package/dist/components/plugins/text-style/underline.js.map +1 -1
  191. package/dist/components/responsive-toolbar.js.map +1 -1
  192. package/dist/components/toolbar/button.js +11 -3
  193. package/dist/components/toolbar/button.js.map +1 -1
  194. package/dist/components/toolbar/divider.js.map +1 -1
  195. package/dist/components/toolbar/dropdown-item.js +10 -4
  196. package/dist/components/toolbar/dropdown-item.js.map +1 -1
  197. package/dist/components/toolbar/dropdown.js +20 -6
  198. package/dist/components/toolbar/dropdown.js.map +1 -1
  199. package/dist/components/toolbar/group.js.map +1 -1
  200. package/dist/components/toolbar/mark.js +22 -11
  201. package/dist/components/toolbar/mark.js.map +1 -1
  202. package/dist/components/toolbar/spacer.js +5 -5
  203. package/dist/components/toolbar/spacer.js.map +1 -1
  204. package/dist/core/keymap.js +1 -1
  205. package/dist/core/say-data-factory/data-factory.js +36 -2
  206. package/dist/core/say-data-factory/data-factory.js.map +1 -1
  207. package/dist/core/say-editor.js +3 -2
  208. package/dist/core/say-editor.js.map +1 -1
  209. package/dist/core/say-node-spec.js.map +1 -1
  210. package/dist/core/schema.js +1 -1
  211. package/dist/nodes/block-rdfa.js.map +1 -1
  212. package/dist/{plugin-D8-O4T0g.js → plugin-D1qUAML5.js} +2 -2
  213. package/dist/{plugin-D8-O4T0g.js.map → plugin-D1qUAML5.js.map} +1 -1
  214. package/dist/plugins/heading/nodes/heading.js +1 -1
  215. package/dist/plugins/heading/nodes/heading.js.map +1 -1
  216. package/dist/plugins/list/commands/lift-out-of-nested-lists.js +1 -1
  217. package/dist/plugins/on-changed/plugin.js +51 -0
  218. package/dist/plugins/on-changed/plugin.js.map +1 -0
  219. package/dist/plugins/rdfa-info/index.js +1 -1
  220. package/dist/plugins/rdfa-info/plugin.js +1 -1
  221. package/dist/plugins/rdfa-info/utils.js +1 -1
  222. package/dist/plugins/remove-properties-of-deleted-nodes/index.js +1 -1
  223. package/dist/utils/_private/datastore/node-map.js.map +1 -1
  224. package/dist/utils/_private/ember-node.js +11 -1
  225. package/dist/utils/_private/ember-node.js.map +1 -1
  226. package/dist/utils/_private/rdfa-utils.js +2 -2
  227. package/dist/utils/_private/types.js.map +1 -1
  228. package/dist/utils/rdfa-utils.js +1 -1
  229. package/dist/utils/transaction-utils.js +30 -5
  230. package/dist/utils/transaction-utils.js.map +1 -1
  231. package/ember-rdfa-editor.scss +1 -0
  232. package/package.json +22 -23
  233. package/scss/_u-utilities.scss +3 -0
  234. package/vendor/ember-rdfa-editor.css +4 -0
  235. package/declarations/components/_private/link-rdfa-node-poc/button.d.ts +0 -26
  236. package/declarations/components/_private/link-rdfa-node-poc/button.d.ts.map +0 -1
  237. package/declarations/components/_private/link-rdfa-node-poc/modal.d.ts +0 -58
  238. package/declarations/components/_private/link-rdfa-node-poc/modal.d.ts.map +0 -1
  239. package/declarations/components/_private/number-editor/index.d.ts.map +0 -1
  240. package/declarations/components/_private/rdfa-editor/backlink-editor/form.d.ts +0 -43
  241. package/declarations/components/_private/rdfa-editor/backlink-editor/form.d.ts.map +0 -1
  242. package/declarations/components/_private/rdfa-editor/backlink-editor/index.d.ts +0 -44
  243. package/declarations/components/_private/rdfa-editor/backlink-editor/index.d.ts.map +0 -1
  244. package/declarations/components/_private/rdfa-editor/configurable-rdfa-display.d.ts.map +0 -1
  245. package/declarations/components/_private/rdfa-editor/doc-imported-resource-editor/form.d.ts.map +0 -1
  246. package/declarations/components/_private/rdfa-editor/doc-imported-resource-editor/index.d.ts +0 -39
  247. package/declarations/components/_private/rdfa-editor/doc-imported-resource-editor/index.d.ts.map +0 -1
  248. package/declarations/components/_private/rdfa-editor/external-triple-editor/form.d.ts.map +0 -1
  249. package/declarations/components/_private/rdfa-editor/external-triple-editor/index.d.ts.map +0 -1
  250. package/declarations/components/_private/rdfa-editor/index.d.ts +0 -25
  251. package/declarations/components/_private/rdfa-editor/index.d.ts.map +0 -1
  252. package/declarations/components/_private/rdfa-editor/object-term-schemas.d.ts.map +0 -1
  253. package/declarations/components/_private/rdfa-editor/property-details.d.ts.map +0 -1
  254. package/declarations/components/_private/rdfa-editor/property-editor/form.d.ts +0 -85
  255. package/declarations/components/_private/rdfa-editor/property-editor/form.d.ts.map +0 -1
  256. package/declarations/components/_private/rdfa-editor/property-editor/index.d.ts +0 -50
  257. package/declarations/components/_private/rdfa-editor/property-editor/index.d.ts.map +0 -1
  258. package/declarations/components/_private/rdfa-editor/rdfa-type-convertor/index.d.ts +0 -1
  259. package/declarations/components/_private/rdfa-editor/rdfa-type-convertor/index.d.ts.map +0 -1
  260. package/declarations/components/_private/rdfa-editor/remove-node/index.d.ts.map +0 -1
  261. package/declarations/components/_private/rdfa-editor/types.d.ts +0 -16
  262. package/declarations/components/_private/rdfa-editor/types.d.ts.map +0 -1
  263. package/declarations/components/_private/rdfa-editor/wrapping-utils/index.d.ts.map +0 -1
  264. package/declarations/components/_private/rdfa-editor/wrapping-utils/modal.d.ts +0 -33
  265. package/declarations/components/_private/rdfa-editor/wrapping-utils/modal.d.ts.map +0 -1
  266. package/declarations/components/_private/selection-tooltip.d.ts.map +0 -1
  267. package/declarations/components/_private/with-unique-id.d.ts.map +0 -1
  268. package/dist/_app_/components/_private/rdfa-editor/backlink-editor/index.js +0 -1
  269. package/dist/_app_/components/_private/rdfa-editor/configurable-rdfa-display.js +0 -1
  270. package/dist/_app_/components/_private/rdfa-editor/doc-imported-resource-editor/form.js +0 -1
  271. package/dist/_app_/components/_private/rdfa-editor/doc-imported-resource-editor/index.js +0 -1
  272. package/dist/_app_/components/_private/rdfa-editor/external-triple-editor/form.js +0 -1
  273. package/dist/_app_/components/_private/rdfa-editor/external-triple-editor/index.js +0 -1
  274. package/dist/_app_/components/_private/rdfa-editor/object-term-schemas.js +0 -1
  275. package/dist/_app_/components/_private/rdfa-editor/property-details.js +0 -1
  276. package/dist/_app_/components/_private/rdfa-editor/property-editor/index.js +0 -1
  277. package/dist/_app_/components/_private/rdfa-editor/rdfa-type-convertor/index.js +0 -1
  278. package/dist/_app_/components/_private/rdfa-editor/remove-node/index.js +0 -1
  279. package/dist/_app_/components/_private/rdfa-editor/wrapping-utils/index.js +0 -1
  280. package/dist/_app_/components/_private/rdfa-editor/wrapping-utils/modal.js +0 -1
  281. package/dist/components/_private/link-rdfa-node-poc/button.js.map +0 -1
  282. package/dist/components/_private/link-rdfa-node-poc/modal.js +0 -102
  283. package/dist/components/_private/link-rdfa-node-poc/modal.js.map +0 -1
  284. package/dist/components/_private/number-editor/index.js.map +0 -1
  285. package/dist/components/_private/rdfa-editor/backlink-editor/form.js +0 -117
  286. package/dist/components/_private/rdfa-editor/backlink-editor/form.js.map +0 -1
  287. package/dist/components/_private/rdfa-editor/backlink-editor/index.js +0 -199
  288. package/dist/components/_private/rdfa-editor/backlink-editor/index.js.map +0 -1
  289. package/dist/components/_private/rdfa-editor/configurable-rdfa-display.js.map +0 -1
  290. package/dist/components/_private/rdfa-editor/doc-imported-resource-editor/form.js.map +0 -1
  291. package/dist/components/_private/rdfa-editor/doc-imported-resource-editor/index.js +0 -213
  292. package/dist/components/_private/rdfa-editor/doc-imported-resource-editor/index.js.map +0 -1
  293. package/dist/components/_private/rdfa-editor/external-triple-editor/form.js.map +0 -1
  294. package/dist/components/_private/rdfa-editor/external-triple-editor/index.js.map +0 -1
  295. package/dist/components/_private/rdfa-editor/index.js +0 -96
  296. package/dist/components/_private/rdfa-editor/index.js.map +0 -1
  297. package/dist/components/_private/rdfa-editor/object-term-schemas.js.map +0 -1
  298. package/dist/components/_private/rdfa-editor/property-details.js.map +0 -1
  299. package/dist/components/_private/rdfa-editor/property-editor/form.js +0 -473
  300. package/dist/components/_private/rdfa-editor/property-editor/form.js.map +0 -1
  301. package/dist/components/_private/rdfa-editor/property-editor/index.js +0 -256
  302. package/dist/components/_private/rdfa-editor/property-editor/index.js.map +0 -1
  303. package/dist/components/_private/rdfa-editor/rdfa-type-convertor/index.js +0 -2
  304. package/dist/components/_private/rdfa-editor/rdfa-type-convertor/index.js.map +0 -1
  305. package/dist/components/_private/rdfa-editor/remove-node/index.js.map +0 -1
  306. package/dist/components/_private/rdfa-editor/wrapping-utils/index.js +0 -132
  307. package/dist/components/_private/rdfa-editor/wrapping-utils/index.js.map +0 -1
  308. package/dist/components/_private/rdfa-editor/wrapping-utils/modal.js +0 -91
  309. package/dist/components/_private/rdfa-editor/wrapping-utils/modal.js.map +0 -1
  310. package/dist/components/_private/selection-tooltip.js.map +0 -1
  311. package/dist/components/_private/with-unique-id.js.map +0 -1
  312. /package/declarations/components/_private/{rdfa-editor → common}/configurable-rdfa-display.d.ts +0 -0
  313. /package/declarations/components/_private/{rdfa-editor → common}/object-term-schemas.d.ts +0 -0
  314. /package/declarations/components/_private/{rdfa-editor → common}/property-details.d.ts +0 -0
  315. /package/declarations/components/_private/{selection-tooltip.d.ts → common/selection-tooltip.d.ts} +0 -0
  316. /package/declarations/components/_private/{rdfa-editor/external-triple-editor → external-triple-editor}/form.d.ts +0 -0
  317. /package/declarations/components/_private/{with-unique-id.d.ts → utils/with-unique-id.d.ts} +0 -0
  318. /package/dist/components/_private/{rdfa-editor → common}/configurable-rdfa-display.js +0 -0
  319. /package/dist/components/_private/{rdfa-editor → common}/object-term-schemas.js +0 -0
  320. /package/dist/components/_private/{rdfa-editor → common}/types.js +0 -0
  321. /package/dist/components/_private/{rdfa-editor → common}/types.js.map +0 -0
  322. /package/dist/components/_private/{with-unique-id.js → utils/with-unique-id.js} +0 -0
@@ -1,256 +0,0 @@
1
- import Component from '@glimmer/component';
2
- import { tracked } from '@glimmer/tracking';
3
- import { addProperty } from '../../../../commands/rdfa-commands/add-property.js';
4
- import { removeProperty } from '../../../../commands/rdfa-commands/remove-property.js';
5
- import 'uuid';
6
- import '../../../../utils/_private/constants.js';
7
- import 'relative-to-absolute-iri';
8
- import 'rdf-data-factory';
9
- import '../../../../main-BcFbMIin.js';
10
- import '../../../../core/say-data-factory/data-factory.js';
11
- import '../../../../core/say-data-factory/default-graph.js';
12
- import '../../../../config/rdfa.js';
13
- import 'iter-tools';
14
- import { i as isLinkToNode, l as getSubjects } from '../../../../plugin-D8-O4T0g.js';
15
- import 'prosemirror-model';
16
- import 'prosemirror-transform';
17
- import 'prosemirror-state';
18
- import { PlusIcon } from '@appuniversum/ember-appuniversum/components/icons/plus';
19
- import { PencilIcon } from '@appuniversum/ember-appuniversum/components/icons/pencil';
20
- import { BinIcon } from '@appuniversum/ember-appuniversum/components/icons/bin';
21
- import { ThreeDotsIcon } from '@appuniversum/ember-appuniversum/components/icons/three-dots';
22
- import AuContent from '@appuniversum/ember-appuniversum/components/au-content';
23
- import AuToolbar from '@appuniversum/ember-appuniversum/components/au-toolbar';
24
- import AuHeading from '@appuniversum/ember-appuniversum/components/au-heading';
25
- import AuButton from '@appuniversum/ember-appuniversum/components/au-button';
26
- import { on } from '@ember/modifier';
27
- import AuList from '@appuniversum/ember-appuniversum/components/au-list';
28
- import AuDropdown from '@appuniversum/ember-appuniversum/components/au-dropdown';
29
- import { fn, array } from '@ember/helper';
30
- import { not } from 'ember-truth-helpers';
31
- import AuAlert from '@appuniversum/ember-appuniversum/components/au-alert';
32
- import { ChevronDownIcon } from '@appuniversum/ember-appuniversum/components/icons/chevron-down';
33
- import AuModal from '@appuniversum/ember-appuniversum/components/au-modal';
34
- import AuButtonGroup from '@appuniversum/ember-appuniversum/components/au-button-group';
35
- import WithUniqueIdComponent from '../../with-unique-id.js';
36
- import PropertyEditorForm from './form.js';
37
- import { isResourceNode } from '../../../../utils/_private/node-utils.js';
38
- import PropertyDetails from '../property-details.js';
39
- import { modifier } from 'ember-modifier';
40
- import { action } from '@ember/object';
41
- import ConfigurableRdfaDisplay, { predicateDisplay } from '../configurable-rdfa-display.js';
42
- import { precompileTemplate } from '@ember/template-compilation';
43
- import { setComponentTemplate } from '@ember/component';
44
- import { g, i, n } from 'decorator-transforms/runtime';
45
-
46
- class RdfaPropertyEditor extends Component {
47
- static {
48
- g(this.prototype, "_statusMessage", [tracked], function () {
49
- return null;
50
- });
51
- }
52
- #_statusMessage = (i(this, "_statusMessage"), void 0);
53
- static {
54
- g(this.prototype, "status", [tracked]);
55
- }
56
- #status = (i(this, "status"), void 0);
57
- isPlainTriple = triple => !isLinkToNode(triple);
58
- setUpListeners = modifier(() => {
59
- const listenerHandler = event => {
60
- if (event.altKey && event.ctrlKey) {
61
- const key = event.key;
62
- switch (key) {
63
- case 'p':
64
- case 'P':
65
- if (this.canAddProperty) {
66
- this.startPropertyCreation();
67
- }
68
- break;
69
- }
70
- }
71
- };
72
- window.addEventListener('keydown', listenerHandler);
73
- return () => {
74
- window.removeEventListener('keydown', listenerHandler);
75
- };
76
- });
77
- get node() {
78
- return this.args.node.value;
79
- }
80
- get controller() {
81
- return this.args.controller;
82
- }
83
- get properties() {
84
- return this.args.node.value.attrs['properties'];
85
- }
86
- get isCreating() {
87
- return this.status?.mode === 'creation';
88
- }
89
- get isUpdating() {
90
- return this.status?.mode === 'update';
91
- }
92
- get currentResource() {
93
- return this.args.node.value.attrs['subject'];
94
- }
95
- get statusMessage() {
96
- // show only if a message is relevant for the current node
97
- if (this._statusMessage && this.node === this._statusMessage.node) {
98
- return this._statusMessage;
99
- }
100
- return null;
101
- }
102
- setStatusMessage = val => {
103
- if (val) {
104
- this._statusMessage = {
105
- ...val,
106
- node: this.node
107
- };
108
- } else {
109
- this._statusMessage = val;
110
- }
111
- };
112
- closeStatusMessage = () => {
113
- this.setStatusMessage(null);
114
- };
115
- get type() {
116
- return this.node.attrs['rdfaNodeType'];
117
- }
118
- get allResources() {
119
- if (!this.controller) {
120
- return [];
121
- }
122
- return getSubjects(this.controller.mainEditorState);
123
- }
124
- get importedResources() {
125
- return this.node.attrs['importedResources'];
126
- }
127
- linkImportedResource = (imported, linked) => {
128
- const newImported = {
129
- ...this.importedResources,
130
- [imported]: linked
131
- };
132
- this.controller?.withTransaction(tr => tr.setNodeAttribute(this.args.node.pos, 'importedResources', newImported));
133
- };
134
- startPropertyCreation = () => {
135
- this.status = {
136
- mode: 'creation'
137
- };
138
- };
139
- startPropertyUpdate = property => {
140
- this.status = {
141
- mode: 'update',
142
- property
143
- };
144
- };
145
- get canAddProperty() {
146
- return isResourceNode(this.node);
147
- }
148
- addProperty = (property, subject) => {
149
- // This function can only be called when the selected node defines a resource or the selected
150
- // node is a document that imports resources (e.g. a snippet)
151
- const resource = this.currentResource || subject;
152
- if (resource) {
153
- this.controller?.doCommand(addProperty({
154
- resource,
155
- property
156
- }), {
157
- view: this.controller.mainEditorView
158
- });
159
- this.status = undefined;
160
- }
161
- };
162
- updateProperty = (newProperty, subject) => {
163
- // TODO: make a command to do this in one go
164
- if (this.status?.mode === 'update') {
165
- this.removeProperty(this.status.property);
166
- this.addProperty(newProperty, subject);
167
- this.status = undefined;
168
- }
169
- };
170
- removeProperty = property => {
171
- // This function can only be called when the selected node defines a resource or the selected
172
- // node is a document that imports resources (e.g. a snippet)
173
- if (this.currentResource) {
174
- const propertyToRemove = {
175
- resource: this.currentResource,
176
- property
177
- };
178
- this.controller?.doCommand(removeProperty(propertyToRemove), {
179
- view: this.controller.mainEditorView
180
- });
181
- }
182
- };
183
- cancel = () => {
184
- this.status = undefined;
185
- };
186
- static {
187
- setComponentTemplate(precompileTemplate("\n <AuContent @skin=\"tiny\" {{this.setUpListeners}}>\n <AuToolbar as |Group|>\n <Group>\n <AuHeading @level=\"5\" @skin=\"5\">Properties</AuHeading>\n </Group>\n <Group>\n <AuButton @disabled={{not this.canAddProperty}} @icon={{PlusIcon}} @skin=\"naked\" {{on \"click\" this.startPropertyCreation}}>\n Add property\n </AuButton>\n </Group>\n </AuToolbar>\n {{#if this.importedResources}}\n <div>\n <AuHeading @level=\"6\" @skin=\"6\" class=\"au-u-margin-bottom-small\">Imported Resources</AuHeading>\n <AuList @divider={{true}} as |Item|>\n {{#each-in this.importedResources as |imported linked|}}\n <Item class=\"au-u-flex au-u-flex--row au-u-flex--between au-u-flex--vertical-center\">\n {{imported}}\n <AuDropdown @icon={{if linked ChevronDownIcon PlusIcon}} @title={{linked}} role=\"menu\" @alignment=\"left\">\n {{#each this.allResources as |res|}}\n <AuButton @skin=\"link\" @icon={{PencilIcon}} role=\"menuitem\" {{on \"click\" (fn this.linkImportedResource imported res)}}>\n {{res}}\n </AuButton>\n {{/each}}\n </AuDropdown>\n </Item>\n {{/each-in}}\n </AuList>\n </div>\n {{/if}}\n {{#if this.properties.length}}\n <AuList @divider={{true}} as |Item|>\n {{#each this.properties as |prop|}}\n <Item class=\"au-u-flex au-u-flex--row au-u-flex--between au-u-flex--vertical-center\">\n <div class=\"au-u-padding-tiny\">\n <ConfigurableRdfaDisplay @value={{prop}} @generator={{predicateDisplay}} @controller={{@controller}} />\n <PropertyDetails @controller={{@controller}} @prop={{prop}} @setStatusMessage={{this.setStatusMessage}} />\n </div>\n <AuDropdown @icon={{ThreeDotsIcon}} role=\"menu\" @alignment=\"left\">\n <AuButton @skin=\"link\" @icon={{PencilIcon}} role=\"menuitem\" {{on \"click\" (fn this.startPropertyUpdate prop)}}>\n Edit property\n </AuButton>\n <AuButton @skin=\"link\" @icon={{BinIcon}} role=\"menuitem\" class=\"au-c-button--alert\" {{on \"click\" (fn this.removeProperty prop)}}>\n Remove property\n </AuButton>\n </AuDropdown>\n </Item>\n {{/each}}\n </AuList>\n {{else}}\n <p>This node doesn't have any properties yet.</p>\n {{/if}}\n {{#if this.statusMessage}}\n <div>\n <AuAlert @skin={{this.statusMessage.type}} @closable={{true}} @onClose={{this.closeStatusMessage}}>\n {{this.statusMessage.message}}\n </AuAlert>\n </div>\n {{/if}}\n </AuContent>\n {{!-- Creation modal --}}\n <Modal @controller={{@controller}} @modalOpen={{this.isCreating}} @onSave={{this.addProperty}} @onCancel={{this.cancel}} @predicateOptions={{@predicateOptions}} @objectOptions={{@objectOptions}} />\n {{!-- Update modal --}}\n <Modal @controller={{@controller}} @modalOpen={{this.isUpdating}} @onSave={{this.updateProperty}} @onCancel={{this.cancel}} {{!-- @glint-expect-error check if property is defined --}} @property={{this.status.property}} @predicateOptions={{@predicateOptions}} @objectOptions={{@objectOptions}} />\n ", {
188
- strictMode: true,
189
- scope: () => ({
190
- AuContent,
191
- AuToolbar,
192
- AuHeading,
193
- AuButton,
194
- not,
195
- PlusIcon,
196
- on,
197
- AuList,
198
- AuDropdown,
199
- ChevronDownIcon,
200
- PencilIcon,
201
- fn,
202
- ConfigurableRdfaDisplay,
203
- predicateDisplay,
204
- PropertyDetails,
205
- ThreeDotsIcon,
206
- BinIcon,
207
- AuAlert,
208
- Modal
209
- })
210
- }), this);
211
- }
212
- }
213
- class Modal extends Component {
214
- onFormKeyDown(formElement, event) {
215
- if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
216
- formElement.requestSubmit();
217
- }
218
- return true;
219
- }
220
- static {
221
- n(this.prototype, "onFormKeyDown", [action]);
222
- }
223
- static {
224
- g(this.prototype, "initiallyFocusedElement", [tracked]);
225
- }
226
- #initiallyFocusedElement = (i(this, "initiallyFocusedElement"), void 0);
227
- initialFocus = modifier(element => {
228
- this.initiallyFocusedElement = element;
229
- });
230
- cancel = () => {
231
- this.args.onCancel();
232
- };
233
- save = (triple, subject) => {
234
- this.args.onSave(triple, subject);
235
- };
236
- get title() {
237
- return this.args.title ?? 'Edit';
238
- }
239
- static {
240
- setComponentTemplate(precompileTemplate("\n <WithUniqueId as |formId|>\n <AuModal @modalOpen={{@modalOpen}} @closable={{true}} @closeModal={{this.cancel}} {{!-- @glint-expect-error appuniversum types should be adapted to accept an html element here --}} @initialFocus={{this.initiallyFocusedElement}}>\n <:title>{{this.title}}</:title>\n <:body>\n <PropertyEditorForm id={{formId}} @initialFocus={{this.initialFocus}} @onSubmit={{this.save}} @termTypes={{array \"NamedNode\" \"Literal\" \"ContentLiteral\" \"LiteralNode\" \"ResourceNode\"}} @controller={{@controller}} @triple={{@property}} @predicateOptions={{@predicateOptions}} @objectOptions={{@objectOptions}} @onKeyDown={{this.onFormKeyDown}} />\n </:body>\n <:footer>\n <AuButtonGroup>\n <AuButton form={{formId}} type=\"submit\">Save</AuButton>\n <AuButton @skin=\"secondary\" {{on \"click\" this.cancel}}>Cancel</AuButton>\n </AuButtonGroup>\n </:footer>\n </AuModal>\n </WithUniqueId>\n ", {
241
- strictMode: true,
242
- scope: () => ({
243
- WithUniqueId: WithUniqueIdComponent,
244
- AuModal,
245
- PropertyEditorForm,
246
- array,
247
- AuButtonGroup,
248
- AuButton,
249
- on
250
- })
251
- }), this);
252
- }
253
- }
254
-
255
- export { RdfaPropertyEditor as default };
256
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/_private/rdfa-editor/property-editor/index.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { tracked } from '@glimmer/tracking';\nimport { addProperty } from '#root/commands/rdfa-commands/add-property.ts';\nimport { removeProperty } from '#root/commands/rdfa-commands/remove-property.ts';\nimport type { ResolvedPNode } from '#root/utils/_private/types.ts';\nimport { type OutgoingTriple } from '#root/core/rdfa-processor.ts';\nimport { isLinkToNode } from '#root/utils/rdfa-utils.ts';\nimport { PlusIcon } from '@appuniversum/ember-appuniversum/components/icons/plus';\nimport { PencilIcon } from '@appuniversum/ember-appuniversum/components/icons/pencil';\nimport { BinIcon } from '@appuniversum/ember-appuniversum/components/icons/bin';\nimport { ThreeDotsIcon } from '@appuniversum/ember-appuniversum/components/icons/three-dots';\nimport type SayController from '#root/core/say-controller.ts';\nimport AuContent from '@appuniversum/ember-appuniversum/components/au-content';\nimport AuToolbar from '@appuniversum/ember-appuniversum/components/au-toolbar';\nimport AuHeading from '@appuniversum/ember-appuniversum/components/au-heading';\nimport AuButton from '@appuniversum/ember-appuniversum/components/au-button';\nimport { on } from '@ember/modifier';\nimport AuList from '@appuniversum/ember-appuniversum/components/au-list';\nimport AuDropdown from '@appuniversum/ember-appuniversum/components/au-dropdown';\nimport { fn } from '@ember/helper';\nimport { not } from 'ember-truth-helpers';\nimport type { PNode } from '#root/prosemirror-aliases.ts';\nimport AuAlert from '@appuniversum/ember-appuniversum/components/au-alert';\nimport { ChevronDownIcon } from '@appuniversum/ember-appuniversum/components/icons/chevron-down';\nimport { getSubjects } from '#root/plugins/rdfa-info/utils.ts';\nimport AuModal from '@appuniversum/ember-appuniversum/components/au-modal';\nimport { array } from '@ember/helper';\nimport AuButtonGroup from '@appuniversum/ember-appuniversum/components/au-button-group';\nimport WithUniqueId from '../../with-unique-id.ts';\nimport PropertyEditorForm from './form.gts';\nimport { isResourceNode } from '#root/utils/node-utils.ts';\nimport { type Status, type StatusMessage } from '../types.ts';\nimport PropertyDetails from '../property-details.gts';\nimport { modifier } from 'ember-modifier';\nimport { action } from '@ember/object';\nimport ConfigurableRdfaDisplay, {\n predicateDisplay,\n} from '../configurable-rdfa-display.gts';\n\ninterface StatusMessageForNode extends StatusMessage {\n node: PNode;\n}\n\ntype Args = {\n controller: SayController;\n node: ResolvedPNode;\n additionalImportedResources?: string[];\n objectOptions?: string[];\n predicateOptions?: string[];\n};\n\nexport default class RdfaPropertyEditor extends Component<Args> {\n @tracked _statusMessage: StatusMessageForNode | null = null;\n @tracked status?: Status;\n\n isPlainTriple = (triple: OutgoingTriple) => !isLinkToNode(triple);\n\n setUpListeners = modifier(() => {\n const listenerHandler = (event: KeyboardEvent) => {\n if (event.altKey && event.ctrlKey) {\n const key = event.key;\n switch (key) {\n case 'p':\n case 'P':\n if (this.canAddProperty) {\n this.startPropertyCreation();\n }\n break;\n }\n }\n };\n window.addEventListener('keydown', listenerHandler);\n return () => {\n window.removeEventListener('keydown', listenerHandler);\n };\n });\n\n get node(): PNode {\n return this.args.node.value;\n }\n\n get controller() {\n return this.args.controller;\n }\n\n get properties() {\n return this.args.node.value.attrs['properties'] as OutgoingTriple[];\n }\n\n get isCreating() {\n return this.status?.mode === 'creation';\n }\n\n get isUpdating() {\n return this.status?.mode === 'update';\n }\n\n get currentResource() {\n return this.args.node.value.attrs['subject'] as string;\n }\n\n get statusMessage(): StatusMessage | null {\n // show only if a message is relevant for the current node\n if (this._statusMessage && this.node === this._statusMessage.node) {\n return this._statusMessage;\n }\n return null;\n }\n setStatusMessage = (val: StatusMessage | null) => {\n if (val) {\n this._statusMessage = { ...val, node: this.node };\n } else {\n this._statusMessage = val;\n }\n };\n\n closeStatusMessage = () => {\n this.setStatusMessage(null);\n };\n\n get type() {\n return this.node.attrs['rdfaNodeType'] as 'resource' | 'literal';\n }\n\n get allResources(): string[] {\n if (!this.controller) {\n return [];\n }\n return getSubjects(this.controller.mainEditorState);\n }\n\n get importedResources(): Record<string, string | undefined> | undefined {\n return this.node.attrs['importedResources'] as\n | Record<string, string | undefined>\n | undefined;\n }\n\n linkImportedResource = (imported: string, linked: string) => {\n const newImported = {\n ...this.importedResources,\n [imported]: linked,\n };\n this.controller?.withTransaction((tr) =>\n tr.setNodeAttribute(this.args.node.pos, 'importedResources', newImported),\n );\n };\n\n startPropertyCreation = () => {\n this.status = {\n mode: 'creation',\n };\n };\n\n startPropertyUpdate = (property: OutgoingTriple) => {\n this.status = {\n mode: 'update',\n property,\n };\n };\n\n get canAddProperty() {\n return isResourceNode(this.node);\n }\n\n addProperty = (property: OutgoingTriple, subject?: string) => {\n // This function can only be called when the selected node defines a resource or the selected\n // node is a document that imports resources (e.g. a snippet)\n const resource = this.currentResource || subject;\n if (resource) {\n this.controller?.doCommand(addProperty({ resource, property }), {\n view: this.controller.mainEditorView,\n });\n this.status = undefined;\n }\n };\n\n updateProperty = (newProperty: OutgoingTriple, subject?: string) => {\n // TODO: make a command to do this in one go\n if (this.status?.mode === 'update') {\n this.removeProperty(this.status.property);\n this.addProperty(newProperty, subject);\n this.status = undefined;\n }\n };\n\n removeProperty = (property: OutgoingTriple) => {\n // This function can only be called when the selected node defines a resource or the selected\n // node is a document that imports resources (e.g. a snippet)\n if (this.currentResource) {\n const propertyToRemove = { resource: this.currentResource, property };\n this.controller?.doCommand(removeProperty(propertyToRemove), {\n view: this.controller.mainEditorView,\n });\n }\n };\n\n cancel = () => {\n this.status = undefined;\n };\n\n <template>\n <AuContent @skin=\"tiny\" {{this.setUpListeners}}>\n <AuToolbar as |Group|>\n <Group>\n <AuHeading @level=\"5\" @skin=\"5\">Properties</AuHeading>\n </Group>\n <Group>\n <AuButton\n @disabled={{not this.canAddProperty}}\n @icon={{PlusIcon}}\n @skin=\"naked\"\n {{on \"click\" this.startPropertyCreation}}\n >\n Add property\n </AuButton>\n </Group>\n </AuToolbar>\n {{#if this.importedResources}}\n <div>\n <AuHeading\n @level=\"6\"\n @skin=\"6\"\n class=\"au-u-margin-bottom-small\"\n >Imported Resources</AuHeading>\n <AuList @divider={{true}} as |Item|>\n {{#each-in this.importedResources as |imported linked|}}\n <Item\n class=\"au-u-flex au-u-flex--row au-u-flex--between au-u-flex--vertical-center\"\n >\n {{imported}}\n <AuDropdown\n @icon={{if linked ChevronDownIcon PlusIcon}}\n @title={{linked}}\n role=\"menu\"\n @alignment=\"left\"\n >\n {{#each this.allResources as |res|}}\n <AuButton\n @skin=\"link\"\n @icon={{PencilIcon}}\n role=\"menuitem\"\n {{on \"click\" (fn this.linkImportedResource imported res)}}\n >\n {{res}}\n </AuButton>\n {{/each}}\n </AuDropdown>\n </Item>\n {{/each-in}}\n </AuList>\n </div>\n {{/if}}\n {{#if this.properties.length}}\n <AuList @divider={{true}} as |Item|>\n {{#each this.properties as |prop|}}\n <Item\n class=\"au-u-flex au-u-flex--row au-u-flex--between au-u-flex--vertical-center\"\n >\n <div class=\"au-u-padding-tiny\">\n <ConfigurableRdfaDisplay\n @value={{prop}}\n @generator={{predicateDisplay}}\n @controller={{@controller}}\n />\n <PropertyDetails\n @controller={{@controller}}\n @prop={{prop}}\n @setStatusMessage={{this.setStatusMessage}}\n />\n </div>\n <AuDropdown @icon={{ThreeDotsIcon}} role=\"menu\" @alignment=\"left\">\n <AuButton\n @skin=\"link\"\n @icon={{PencilIcon}}\n role=\"menuitem\"\n {{on \"click\" (fn this.startPropertyUpdate prop)}}\n >\n Edit property\n </AuButton>\n <AuButton\n @skin=\"link\"\n @icon={{BinIcon}}\n role=\"menuitem\"\n class=\"au-c-button--alert\"\n {{on \"click\" (fn this.removeProperty prop)}}\n >\n Remove property\n </AuButton>\n </AuDropdown>\n </Item>\n {{/each}}\n </AuList>\n {{else}}\n <p>This node doesn't have any properties yet.</p>\n {{/if}}\n {{#if this.statusMessage}}\n <div>\n <AuAlert\n @skin={{this.statusMessage.type}}\n @closable={{true}}\n @onClose={{this.closeStatusMessage}}\n >\n {{this.statusMessage.message}}\n </AuAlert>\n </div>\n {{/if}}\n </AuContent>\n {{! Creation modal }}\n <Modal\n @controller={{@controller}}\n @modalOpen={{this.isCreating}}\n @onSave={{this.addProperty}}\n @onCancel={{this.cancel}}\n @predicateOptions={{@predicateOptions}}\n @objectOptions={{@objectOptions}}\n />\n {{! Update modal }}\n <Modal\n @controller={{@controller}}\n @modalOpen={{this.isUpdating}}\n @onSave={{this.updateProperty}}\n @onCancel={{this.cancel}}\n {{! @glint-expect-error check if property is defined }}\n @property={{this.status.property}}\n @predicateOptions={{@predicateOptions}}\n @objectOptions={{@objectOptions}}\n />\n </template>\n}\n\ninterface Sig {\n Args: {\n controller?: SayController;\n property?: OutgoingTriple;\n onCancel: () => void;\n onSave: (property: OutgoingTriple, subject?: string) => void;\n modalOpen: boolean;\n title?: string;\n predicateOptions?: string[];\n objectOptions?: string[];\n };\n}\n\nclass Modal extends Component<Sig> {\n @action\n onFormKeyDown(formElement: HTMLFormElement, event: KeyboardEvent) {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n formElement.requestSubmit();\n }\n return true;\n }\n\n @tracked initiallyFocusedElement?: HTMLElement;\n\n initialFocus = modifier((element: HTMLElement) => {\n this.initiallyFocusedElement = element;\n });\n\n cancel = () => {\n this.args.onCancel();\n };\n\n save = (triple: OutgoingTriple, subject?: string) => {\n this.args.onSave(triple, subject);\n };\n get title() {\n return this.args.title ?? 'Edit';\n }\n <template>\n <WithUniqueId as |formId|>\n <AuModal\n @modalOpen={{@modalOpen}}\n @closable={{true}}\n @closeModal={{this.cancel}}\n {{! @glint-expect-error appuniversum types should be adapted to accept an html element here }}\n @initialFocus={{this.initiallyFocusedElement}}\n >\n <:title>{{this.title}}</:title>\n <:body>\n <PropertyEditorForm\n id={{formId}}\n @initialFocus={{this.initialFocus}}\n @onSubmit={{this.save}}\n @termTypes={{array\n \"NamedNode\"\n \"Literal\"\n \"ContentLiteral\"\n \"LiteralNode\"\n \"ResourceNode\"\n }}\n @controller={{@controller}}\n @triple={{@property}}\n @predicateOptions={{@predicateOptions}}\n @objectOptions={{@objectOptions}}\n @onKeyDown={{this.onFormKeyDown}}\n />\n </:body>\n <:footer>\n <AuButtonGroup>\n <AuButton form={{formId}} type=\"submit\">Save</AuButton>\n <AuButton\n @skin=\"secondary\"\n {{on \"click\" this.cancel}}\n >Cancel</AuButton>\n </AuButtonGroup>\n </:footer>\n </AuModal>\n </WithUniqueId>\n </template>\n}\n"],"names":["RdfaPropertyEditor","Component","g","prototype","tracked","i","void 0","isPlainTriple","triple","isLinkToNode","setUpListeners","modifier","listenerHandler","event","altKey","ctrlKey","key","canAddProperty","startPropertyCreation","window","addEventListener","removeEventListener","node","args","value","controller","properties","attrs","isCreating","status","mode","isUpdating","currentResource","statusMessage","_statusMessage","setStatusMessage","val","closeStatusMessage","type","allResources","getSubjects","mainEditorState","importedResources","linkImportedResource","imported","linked","newImported","withTransaction","tr","setNodeAttribute","pos","startPropertyUpdate","property","isResourceNode","addProperty","subject","resource","doCommand","view","mainEditorView","undefined","updateProperty","newProperty","removeProperty","propertyToRemove","cancel","setComponentTemplate","precompileTemplate","strictMode","scope","AuContent","AuToolbar","AuHeading","AuButton","not","PlusIcon","on","AuList","AuDropdown","ChevronDownIcon","PencilIcon","fn","ConfigurableRdfaDisplay","predicateDisplay","PropertyDetails","ThreeDotsIcon","BinIcon","AuAlert","Modal","onFormKeyDown","formElement","metaKey","requestSubmit","n","action","initialFocus","element","initiallyFocusedElement","onCancel","save","onSave","title","WithUniqueId","AuModal","PropertyEditorForm","array","AuButtonGroup"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
-
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/_private/rdfa-editor/remove-node/index.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { tracked } from '@glimmer/tracking';\nimport { AlertTriangleIcon } from '@appuniversum/ember-appuniversum/components/icons/alert-triangle';\n\nimport type { ResolvedPNode } from '#root/utils/_private/types.ts';\nimport type SayController from '#root/core/say-controller.ts';\nimport AuButton from '@appuniversum/ember-appuniversum/components/au-button';\nimport { on } from '@ember/modifier';\nimport { not } from 'ember-truth-helpers';\nimport AuModal from '@appuniversum/ember-appuniversum/components/au-modal';\nimport AuAlert from '@appuniversum/ember-appuniversum/components/au-alert';\nimport AuButtonGroup from '@appuniversum/ember-appuniversum/components/au-button-group';\n\ntype Args = {\n node: ResolvedPNode;\n controller: SayController;\n};\n\nexport default class RemoveNode extends Component<Args> {\n AlertTriangleIcon = AlertTriangleIcon;\n\n @tracked showDialog = false;\n\n get controller() {\n return this.args.controller;\n }\n\n get node() {\n return this.args.node;\n }\n\n showConfirmationDialog = () => {\n this.showDialog = true;\n };\n\n closeConfirmationDialog = () => {\n this.showDialog = false;\n };\n\n confirmDelete = () => {\n this.deleteNode();\n this.closeConfirmationDialog();\n };\n\n deleteNode = () => {\n this.controller.withTransaction((tr) => {\n return tr.deleteRange(\n this.node.pos,\n this.node.pos + this.node.value.nodeSize,\n );\n });\n };\n\n get enabled() {\n return this.args.node.pos !== -1;\n }\n\n <template>\n <AuButton\n @width=\"block\"\n @alert={{true}}\n {{on \"click\" this.showConfirmationDialog}}\n @disabled={{not this.enabled}}\n >\n Remove node\n </AuButton>\n <AuModal\n @title=\"Delete RDFA Node\"\n @modalOpen={{this.showDialog}}\n @closeModal={{this.closeConfirmationDialog}}\n as |Modal|\n >\n <Modal.Body>\n <AuAlert\n @title=\"Delete RDFA node\"\n @skin=\"warning\"\n @icon={{this.AlertTriangleIcon}}\n >\n Are you sure you want to delete this RDFA node?\n </AuAlert>\n </Modal.Body>\n\n <Modal.Footer>\n <AuButtonGroup>\n <AuButton {{on \"click\" this.confirmDelete}} @skin=\"primary\">\n Yes\n </AuButton>\n <AuButton\n {{on \"click\" this.closeConfirmationDialog}}\n @skin=\"secondary\"\n >\n No\n </AuButton>\n </AuButtonGroup>\n </Modal.Footer>\n </AuModal>\n </template>\n}\n"],"names":["RemoveNode","Component","AlertTriangleIcon","g","prototype","tracked","i","void 0","controller","args","node","showConfirmationDialog","showDialog","closeConfirmationDialog","confirmDelete","deleteNode","withTransaction","tr","deleteRange","pos","value","nodeSize","enabled","setComponentTemplate","precompileTemplate","strictMode","scope","AuButton","not","on","AuModal","AuAlert","AuButtonGroup"],"mappings":";;;;;;;;;;;;;AAkBe,MAAMA,mBAAmBC,SAAU,CAAA;AAChDC,EAAAA,iBAAA,GAAoBA,iBAAkB;AAAA,EAAA;IAAAC,CAAA,CAAA,IAAA,CAAAC,SAAA,EAAA,YAAA,EAAA,CAErCC,OAAA,CAAA,EAAA,YAAA;AAAA,MAAA,OAAqB,KAAM;AAAA,KAAA,CAAA;AAAA;AAAA,EAAA,WAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,YAAA,CAAA,EAAAC,MAAA;EAE5B,IAAIC,UAAaA,GAAA;AACf,IAAA,OAAO,IAAI,CAACC,IAAI,CAACD,UAAU;AAC7B;EAEA,IAAIE,IAAOA,GAAA;AACT,IAAA,OAAO,IAAI,CAACD,IAAI,CAACC,IAAI;AACvB;EAEAC,sBAAyB,GAAAA,MAAA;IACvB,IAAI,CAACC,UAAU,GAAG,IAAA;GAClB;EAEFC,uBAA0B,GAAAA,MAAA;IACxB,IAAI,CAACD,UAAU,GAAG,KAAA;GAClB;EAEFE,aAAgB,GAAAA,MAAA;IACd,IAAI,CAACC,UAAU,EAAA;IACf,IAAI,CAACF,uBAAuB,EAAA;GAC5B;EAEFE,UAAa,GAAAA,MAAA;AACX,IAAA,IAAI,CAACP,UAAU,CAACQ,eAAe,CAAEC,EAAA,IAAA;MAC/B,OAAOA,EAAA,CAAGC,WAAW,CACnB,IAAI,CAACR,IAAI,CAACS,GAAG,EACb,IAAI,CAACT,IAAI,CAACS,GAAG,GAAG,IAAI,CAACT,IAAI,CAACU,KAAK,CAACC,QAAQ,CAAA;AAE5C,KAAA,CAAA;GACA;EAEF,IAAIC,OAAUA,GAAA;IACZ,OAAO,IAAI,CAACb,IAAI,CAACC,IAAI,CAACS,GAAG,KAAK,EAAC;AACjC;AAEA,EAAA;IAAAI,oBAAA,CAAAC,kBAAA,CAuCA,w2BAAA,EAAA;MAAAC,UAAA,EAAA,IAAA;AAAAC,MAAAA,KAAA,EAAAA,OAAA;QAAAC,QAAA;QAAAC,GAAA;QAAAC,EAAA;QAAAC,OAAA;QAAAC,OAAA;AAAAC,QAAAA;AAAA,OAAA;KAAU,CAAA,EAAV,IAAW,CAAA;AAAD;AACZ;;;;"}
@@ -1,132 +0,0 @@
1
- import Component from '@glimmer/component';
2
- import { tracked } from '@glimmer/tracking';
3
- import '../../../../plugin-D8-O4T0g.js';
4
- import 'prosemirror-state';
5
- import 'prosemirror-model';
6
- import 'prosemirror-transform';
7
- import '../../../../core/say-data-factory/data-factory.js';
8
- import '../../../../core/say-data-factory/default-graph.js';
9
- import '../../../../utils/_private/constants.js';
10
- import 'uuid';
11
- import 'relative-to-absolute-iri';
12
- import 'rdf-data-factory';
13
- import '../../../../main-BcFbMIin.js';
14
- import '../../../../config/rdfa.js';
15
- import 'iter-tools';
16
- import { wrapResource } from '../../../../commands/_private/rdfa-commands/wrap-resource.js';
17
- import { wrapLiteral } from '../../../../commands/_private/rdfa-commands/wrap-literal.js';
18
- import { wrapInlineLiteral } from '../../../../commands/_private/rdfa-commands/wrap-inline-literal.js';
19
- import { wrapInlineResource } from '../../../../commands/_private/rdfa-commands/wrap-inline-resource.js';
20
- import RelationshipEditorModal from './modal.js';
21
- import { PlusIcon } from '@appuniversum/ember-appuniversum/components/icons/plus';
22
- import AuContent from '@appuniversum/ember-appuniversum/components/au-content';
23
- import AuToolbar from '@appuniversum/ember-appuniversum/components/au-toolbar';
24
- import AuButton from '@appuniversum/ember-appuniversum/components/au-button';
25
- import { on } from '@ember/modifier';
26
- import { fn } from '@ember/helper';
27
- import { not } from 'ember-truth-helpers';
28
- import { modifier } from 'ember-modifier';
29
- import { precompileTemplate } from '@ember/template-compilation';
30
- import { setComponentTemplate } from '@ember/component';
31
- import { g, i } from 'decorator-transforms/runtime';
32
-
33
- class WrappingUtils extends Component {
34
- static {
35
- g(this.prototype, "modalOpen", [tracked], function () {
36
- return false;
37
- });
38
- }
39
- #modalOpen = (i(this, "modalOpen"), void 0);
40
- static {
41
- g(this.prototype, "wrapWithResource", [tracked]);
42
- }
43
- #wrapWithResource = (i(this, "wrapWithResource"), void 0);
44
- constructor(owner, args) {
45
- super(owner, args);
46
- this.wrapWithResource = this.wrapWithBlockResource;
47
- }
48
- setUpListeners = modifier(() => {
49
- const listenerHandler = event => {
50
- if (event.altKey && event.ctrlKey) {
51
- const key = event.key;
52
- switch (key) {
53
- case 'r':
54
- // Wrap with block resource
55
- this.openModal(false);
56
- break;
57
- case 'R':
58
- // Wrap with inline resource
59
- this.openModal(true);
60
- break;
61
- case 'l':
62
- // Wrap with block literal
63
- this.wrapWithLiteralNode();
64
- break;
65
- case 'L':
66
- // Wrap with inline literal
67
- this.wrapWithInlineLiteralNode();
68
- break;
69
- }
70
- }
71
- };
72
- window.addEventListener('keydown', listenerHandler);
73
- return () => {
74
- window.removeEventListener('keydown', listenerHandler);
75
- };
76
- });
77
- openModal = inline => {
78
- if (inline) {
79
- this.wrapWithResource = this.wrapWithInlineResource;
80
- } else {
81
- this.wrapWithResource = this.wrapWithBlockResource;
82
- }
83
- this.modalOpen = true;
84
- };
85
- closeModal = () => {
86
- this.modalOpen = false;
87
- };
88
- get controller() {
89
- return this.args.controller;
90
- }
91
- get currentResource() {
92
- return this.args.node.value.attrs['subject'];
93
- }
94
- get canWrapWithLiteral() {
95
- return this.controller?.checkCommand(wrapLiteral());
96
- }
97
- get canWrapWithInlineLiteral() {
98
- return this.controller?.checkCommand(wrapInlineLiteral());
99
- }
100
- wrapWithLiteralNode = () => {
101
- this.controller?.doCommand(wrapLiteral());
102
- };
103
- wrapWithBlockResource = details => {
104
- this.controller?.doCommand(wrapResource(details));
105
- this.closeModal();
106
- };
107
- wrapWithInlineLiteralNode = () => {
108
- this.controller?.doCommand(wrapInlineLiteral());
109
- };
110
- wrapWithInlineResource = details => {
111
- this.controller?.doCommand(wrapInlineResource(details));
112
- this.closeModal();
113
- };
114
- static {
115
- setComponentTemplate(precompileTemplate("\n <AuContent @skin=\"tiny\" {{this.setUpListeners}}>\n <AuToolbar as |Group|>\n <Group>\n <AuButton @icon={{PlusIcon}} @skin=\"naked\" {{on \"click\" (fn this.openModal false)}}>\n Wrap With Block Resource\n </AuButton>\n </Group>\n <Group>\n <AuButton @icon={{PlusIcon}} @skin=\"naked\" @disabled={{not this.canWrapWithLiteral}} {{on \"click\" this.wrapWithLiteralNode}}>\n Wrap With Block Literal\n </AuButton>\n </Group>\n\n <Group>\n <AuButton @icon={{PlusIcon}} @skin=\"naked\" {{on \"click\" (fn this.openModal true)}}>\n Wrap With Inline Resource\n </AuButton>\n </Group>\n <Group>\n <AuButton @icon={{PlusIcon}} @skin=\"naked\" @disabled={{not this.canWrapWithInlineLiteral}} {{on \"click\" this.wrapWithInlineLiteralNode}}>\n Wrap With Inline Literal\n </AuButton>\n </Group>\n </AuToolbar>\n </AuContent>\n\n <WrappingModal @modalOpen={{this.modalOpen}} @closeModal={{this.closeModal}} @wrapWithResource={{this.wrapWithResource}} />\n ", {
116
- strictMode: true,
117
- scope: () => ({
118
- AuContent,
119
- AuToolbar,
120
- AuButton,
121
- PlusIcon,
122
- on,
123
- fn,
124
- not,
125
- WrappingModal: RelationshipEditorModal
126
- })
127
- }), this);
128
- }
129
- }
130
-
131
- export { WrappingUtils as default };
132
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/_private/rdfa-editor/wrapping-utils/index.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { tracked } from '@glimmer/tracking';\nimport {\n wrapInlineResource,\n wrapLiteral,\n wrapResource,\n} from '#root/commands/_private/rdfa-commands/index.ts';\nimport WrappingModal from './modal.gts';\nimport type { ResolvedPNode } from '#root/utils/_private/types.ts';\nimport { wrapInlineLiteral } from '#root/commands/_private/rdfa-commands/wrap-inline-literal.ts';\nimport { PlusIcon } from '@appuniversum/ember-appuniversum/components/icons/plus';\nimport type SayController from '#root/core/say-controller.ts';\nimport AuContent from '@appuniversum/ember-appuniversum/components/au-content';\nimport AuToolbar from '@appuniversum/ember-appuniversum/components/au-toolbar';\nimport AuButton from '@appuniversum/ember-appuniversum/components/au-button';\nimport { on } from '@ember/modifier';\nimport { fn } from '@ember/helper';\nimport { not } from 'ember-truth-helpers';\nimport { modifier } from 'ember-modifier';\n\ntype Args = {\n controller?: SayController;\n node: ResolvedPNode;\n};\n\nexport default class WrappingUtils extends Component<Args> {\n @tracked modalOpen = false;\n @tracked wrapWithResource;\n\n constructor(owner: unknown, args: Args) {\n super(owner, args);\n this.wrapWithResource = this.wrapWithBlockResource;\n }\n\n setUpListeners = modifier(() => {\n const listenerHandler = (event: KeyboardEvent) => {\n if (event.altKey && event.ctrlKey) {\n const key = event.key;\n switch (key) {\n case 'r':\n // Wrap with block resource\n this.openModal(false);\n break;\n case 'R':\n // Wrap with inline resource\n this.openModal(true);\n break;\n case 'l':\n // Wrap with block literal\n this.wrapWithLiteralNode();\n break;\n case 'L':\n // Wrap with inline literal\n this.wrapWithInlineLiteralNode();\n break;\n }\n }\n };\n window.addEventListener('keydown', listenerHandler);\n return () => {\n window.removeEventListener('keydown', listenerHandler);\n };\n });\n\n openModal = (inline: boolean) => {\n if (inline) {\n this.wrapWithResource = this.wrapWithInlineResource;\n } else {\n this.wrapWithResource = this.wrapWithBlockResource;\n }\n this.modalOpen = true;\n };\n\n closeModal = () => {\n this.modalOpen = false;\n };\n\n get controller() {\n return this.args.controller;\n }\n\n get currentResource() {\n return this.args.node.value.attrs['subject'] as string | undefined;\n }\n\n get canWrapWithLiteral() {\n return this.controller?.checkCommand(wrapLiteral());\n }\n get canWrapWithInlineLiteral() {\n return this.controller?.checkCommand(wrapInlineLiteral());\n }\n wrapWithLiteralNode = () => {\n this.controller?.doCommand(wrapLiteral());\n };\n\n wrapWithBlockResource = (details: Parameters<typeof wrapResource>[0]) => {\n this.controller?.doCommand(wrapResource(details));\n this.closeModal();\n };\n wrapWithInlineLiteralNode = () => {\n this.controller?.doCommand(wrapInlineLiteral());\n };\n wrapWithInlineResource = (details: Parameters<typeof wrapResource>[0]) => {\n this.controller?.doCommand(wrapInlineResource(details));\n this.closeModal();\n };\n\n <template>\n <AuContent @skin=\"tiny\" {{this.setUpListeners}}>\n <AuToolbar as |Group|>\n <Group>\n <AuButton\n @icon={{PlusIcon}}\n @skin=\"naked\"\n {{on \"click\" (fn this.openModal false)}}\n >\n Wrap With Block Resource\n </AuButton>\n </Group>\n <Group>\n <AuButton\n @icon={{PlusIcon}}\n @skin=\"naked\"\n @disabled={{not this.canWrapWithLiteral}}\n {{on \"click\" this.wrapWithLiteralNode}}\n >\n Wrap With Block Literal\n </AuButton>\n </Group>\n\n <Group>\n <AuButton\n @icon={{PlusIcon}}\n @skin=\"naked\"\n {{on \"click\" (fn this.openModal true)}}\n >\n Wrap With Inline Resource\n </AuButton>\n </Group>\n <Group>\n <AuButton\n @icon={{PlusIcon}}\n @skin=\"naked\"\n @disabled={{not this.canWrapWithInlineLiteral}}\n {{on \"click\" this.wrapWithInlineLiteralNode}}\n >\n Wrap With Inline Literal\n </AuButton>\n </Group>\n </AuToolbar>\n </AuContent>\n\n <WrappingModal\n @modalOpen={{this.modalOpen}}\n @closeModal={{this.closeModal}}\n @wrapWithResource={{this.wrapWithResource}}\n />\n </template>\n}\n"],"names":["WrappingUtils","Component","g","prototype","tracked","i","void 0","constructor","owner","args","wrapWithResource","wrapWithBlockResource","setUpListeners","modifier","listenerHandler","event","altKey","ctrlKey","key","openModal","wrapWithLiteralNode","wrapWithInlineLiteralNode","window","addEventListener","removeEventListener","inline","wrapWithInlineResource","modalOpen","closeModal","controller","currentResource","node","value","attrs","canWrapWithLiteral","checkCommand","wrapLiteral","canWrapWithInlineLiteral","wrapInlineLiteral","doCommand","details","wrapResource","wrapInlineResource","setComponentTemplate","precompileTemplate","strictMode","scope","AuContent","AuToolbar","AuButton","PlusIcon","on","fn","not","WrappingModal"],"mappings":"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"}
@@ -1,91 +0,0 @@
1
- import Component from '@glimmer/component';
2
- import { tracked } from '@glimmer/tracking';
3
- import AuModal from '@appuniversum/ember-appuniversum/components/au-modal';
4
- import AuFormRow from '@appuniversum/ember-appuniversum/components/au-form-row';
5
- import AuLabel from '@appuniversum/ember-appuniversum/components/au-label';
6
- import AuInput from '@appuniversum/ember-appuniversum/components/au-input';
7
- import AuButtonGroup from '@appuniversum/ember-appuniversum/components/au-button-group';
8
- import AuButton from '@appuniversum/ember-appuniversum/components/au-button';
9
- import AuRadioGroup from '@appuniversum/ember-appuniversum/components/au-radio-group';
10
- import { not } from 'ember-truth-helpers';
11
- import { on } from '@ember/modifier';
12
- import { modifier } from 'ember-modifier';
13
- import WithUniqueIdComponent from '../../with-unique-id.js';
14
- import { precompileTemplate } from '@ember/template-compilation';
15
- import { setComponentTemplate } from '@ember/component';
16
- import { g, i } from 'decorator-transforms/runtime';
17
-
18
- class RelationshipEditorModal extends Component {
19
- static {
20
- g(this.prototype, "initiallyFocusedElement", [tracked]);
21
- }
22
- #initiallyFocusedElement = (i(this, "initiallyFocusedElement"), void 0);
23
- setupFormSubmitShortcut = modifier(formElement => {
24
- const ctrlEnterHandler = event => {
25
- if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
26
- formElement.requestSubmit();
27
- }
28
- };
29
- window.addEventListener('keydown', ctrlEnterHandler);
30
- return () => window.removeEventListener('keydown', ctrlEnterHandler);
31
- });
32
- initialFocus = modifier(element => {
33
- this.initiallyFocusedElement = element;
34
- });
35
- static {
36
- g(this.prototype, "generateNewUri", [tracked], function () {
37
- return 'yes';
38
- });
39
- }
40
- #generateNewUri = (i(this, "generateNewUri"), void 0);
41
- static {
42
- g(this.prototype, "resourceUriBase", [tracked], function () {
43
- return '';
44
- });
45
- }
46
- #resourceUriBase = (i(this, "resourceUriBase"), void 0);
47
- updateUriBase = event => {
48
- this.resourceUriBase = event.target.value;
49
- };
50
- shouldGenerateNewUri = value => {
51
- this.generateNewUri = value;
52
- };
53
- save = event => {
54
- event.preventDefault();
55
- if (this.isNewUri) {
56
- this.args.wrapWithResource({
57
- uriBase: this.resourceUriBase
58
- });
59
- } else {
60
- this.args.wrapWithResource({
61
- existingUri: this.resourceUriBase
62
- });
63
- }
64
- };
65
- get canSave() {
66
- return !!this.resourceUriBase;
67
- }
68
- get isNewUri() {
69
- return this.generateNewUri === 'yes';
70
- }
71
- static {
72
- setComponentTemplate(precompileTemplate("\n <WithUniqueId as |formId|>\n <AuModal @modalOpen={{@modalOpen}} @closable={{true}} @closeModal={{@closeModal}} {{!-- @glint-expect-error appuniversum types should be adapted to accept an html element here --}} @initialFocus={{this.initiallyFocusedElement}}>\n <:title>Wrap selection</:title>\n <:body>\n <form class=\"au-c-form\" id={{formId}} {{on \"submit\" this.save}} {{this.setupFormSubmitShortcut}}>\n <AuFormRow>\n <WithUniqueId as |id|>\n <AuLabel for={{id}} @required={{true}} @requiredLabel=\"Required\">\n Generate new URI?\n </AuLabel>\n <AuRadioGroup id={{id}} required={{true}} @name=\"isNew\" @selected={{this.generateNewUri}} @onChange={{this.shouldGenerateNewUri}} @alignment=\"inline\" as |Group|>\n <Group.Radio @value=\"yes\">Yes</Group.Radio>\n <Group.Radio @value=\"no\">No</Group.Radio>\n </AuRadioGroup>\n </WithUniqueId>\n </AuFormRow>\n <AuFormRow>\n <WithUniqueId as |id|>\n <AuLabel for={{id}} @required={{true}} @requiredLabel=\"Required\">\n {{#if this.isNewUri}}URI base{{else}}Existing URI{{/if}}\n </AuLabel>\n <AuInput {{this.initialFocus}} id={{id}} required={{true}} value={{this.resourceUriBase}} @width=\"block\" placeholder=\"http://example.com/resource/\" {{on \"input\" this.updateUriBase}} />\n </WithUniqueId>\n </AuFormRow>\n </form>\n </:body>\n <:footer>\n <AuButtonGroup>\n <AuButton form={{formId}} type=\"submit\" @disabled={{not this.canSave}}>\n Save\n </AuButton>\n <AuButton @skin=\"secondary\" {{on \"click\" @closeModal}}>Cancel</AuButton>\n </AuButtonGroup>\n </:footer>\n </AuModal>\n </WithUniqueId>\n ", {
73
- strictMode: true,
74
- scope: () => ({
75
- WithUniqueId: WithUniqueIdComponent,
76
- AuModal,
77
- on,
78
- AuFormRow,
79
- AuLabel,
80
- AuRadioGroup,
81
- AuInput,
82
- AuButtonGroup,
83
- AuButton,
84
- not
85
- })
86
- }), this);
87
- }
88
- }
89
-
90
- export { RelationshipEditorModal as default };
91
- //# sourceMappingURL=modal.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"modal.js","sources":["../../../../../src/components/_private/rdfa-editor/wrapping-utils/modal.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { tracked } from '@glimmer/tracking';\nimport type RdfaWrappingUtils from './index.ts';\nimport AuModal from '@appuniversum/ember-appuniversum/components/au-modal';\nimport AuFormRow from '@appuniversum/ember-appuniversum/components/au-form-row';\nimport AuLabel from '@appuniversum/ember-appuniversum/components/au-label';\nimport AuInput from '@appuniversum/ember-appuniversum/components/au-input';\nimport AuButtonGroup from '@appuniversum/ember-appuniversum/components/au-button-group';\nimport AuButton from '@appuniversum/ember-appuniversum/components/au-button';\nimport AuRadioGroup from '@appuniversum/ember-appuniversum/components/au-radio-group';\nimport { not } from 'ember-truth-helpers';\nimport { on } from '@ember/modifier';\nimport { modifier } from 'ember-modifier';\nimport WithUniqueId from '../../with-unique-id.ts';\n\ntype Args = {\n closeModal: () => void;\n modalOpen: boolean;\n wrapWithResource: RdfaWrappingUtils['wrapWithResource'];\n};\n\nexport default class RelationshipEditorModal extends Component<Args> {\n @tracked initiallyFocusedElement?: HTMLElement;\n\n setupFormSubmitShortcut = modifier((formElement: HTMLFormElement) => {\n const ctrlEnterHandler = (event: KeyboardEvent) => {\n if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {\n formElement.requestSubmit();\n }\n };\n window.addEventListener('keydown', ctrlEnterHandler);\n return () => window.removeEventListener('keydown', ctrlEnterHandler);\n });\n\n initialFocus = modifier((element: HTMLElement) => {\n this.initiallyFocusedElement = element;\n });\n\n @tracked generateNewUri = 'yes';\n @tracked resourceUriBase = '';\n\n updateUriBase = (event: InputEvent) => {\n this.resourceUriBase = (event.target as HTMLInputElement).value;\n };\n shouldGenerateNewUri = (value: 'yes' | 'no') => {\n this.generateNewUri = value;\n };\n\n save = (event: Event) => {\n event.preventDefault();\n if (this.isNewUri) {\n this.args.wrapWithResource({ uriBase: this.resourceUriBase });\n } else {\n this.args.wrapWithResource({ existingUri: this.resourceUriBase });\n }\n };\n\n get canSave() {\n return !!this.resourceUriBase;\n }\n get isNewUri() {\n return this.generateNewUri === 'yes';\n }\n\n <template>\n <WithUniqueId as |formId|>\n <AuModal\n @modalOpen={{@modalOpen}}\n @closable={{true}}\n @closeModal={{@closeModal}}\n {{! @glint-expect-error appuniversum types should be adapted to accept an html element here }}\n @initialFocus={{this.initiallyFocusedElement}}\n >\n <:title>Wrap selection</:title>\n <:body>\n <form\n class=\"au-c-form\"\n id={{formId}}\n {{on \"submit\" this.save}}\n {{this.setupFormSubmitShortcut}}\n >\n <AuFormRow>\n <WithUniqueId as |id|>\n <AuLabel\n for={{id}}\n @required={{true}}\n @requiredLabel=\"Required\"\n >\n Generate new URI?\n </AuLabel>\n <AuRadioGroup\n id={{id}}\n required={{true}}\n @name=\"isNew\"\n @selected={{this.generateNewUri}}\n @onChange={{this.shouldGenerateNewUri}}\n @alignment=\"inline\"\n as |Group|\n >\n <Group.Radio @value=\"yes\">Yes</Group.Radio>\n <Group.Radio @value=\"no\">No</Group.Radio>\n </AuRadioGroup>\n </WithUniqueId>\n </AuFormRow>\n <AuFormRow>\n <WithUniqueId as |id|>\n <AuLabel\n for={{id}}\n @required={{true}}\n @requiredLabel=\"Required\"\n >\n {{#if this.isNewUri}}URI base{{else}}Existing URI{{/if}}\n </AuLabel>\n <AuInput\n {{this.initialFocus}}\n id={{id}}\n required={{true}}\n value={{this.resourceUriBase}}\n @width=\"block\"\n placeholder=\"http://example.com/resource/\"\n {{on \"input\" this.updateUriBase}}\n />\n </WithUniqueId>\n </AuFormRow>\n </form>\n </:body>\n <:footer>\n <AuButtonGroup>\n <AuButton\n form={{formId}}\n type=\"submit\"\n @disabled={{not this.canSave}}\n >\n Save\n </AuButton>\n <AuButton\n @skin=\"secondary\"\n {{on \"click\" @closeModal}}\n >Cancel</AuButton>\n </AuButtonGroup>\n </:footer>\n </AuModal>\n </WithUniqueId>\n </template>\n}\n"],"names":["RelationshipEditorModal","Component","g","prototype","tracked","i","void 0","setupFormSubmitShortcut","modifier","formElement","ctrlEnterHandler","event","key","ctrlKey","metaKey","requestSubmit","window","addEventListener","removeEventListener","initialFocus","element","initiallyFocusedElement","updateUriBase","resourceUriBase","target","value","shouldGenerateNewUri","generateNewUri","save","preventDefault","isNewUri","args","wrapWithResource","uriBase","existingUri","canSave","setComponentTemplate","precompileTemplate","strictMode","scope","WithUniqueId","AuModal","on","AuFormRow","AuLabel","AuRadioGroup","AuInput","AuButtonGroup","AuButton","not"],"mappings":";;;;;;;;;;;;;;;;;AAqBe,MAAMA,gCAAgCC,SAAU,CAAA;AAAA,EAAA;IAAAC,CAAA,CAAA,IAAA,CAAAC,SAAA,EAAA,yBAAA,EAAA,CAC5DC,OAAA,CAAA,CAAA;AAAA;AAAA,EAAA,wBAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,yBAAA,CAAA,EAAAC,MAAA;AAEDC,EAAAA,uBAA0B,GAAAC,QAAA,CAAUC,WAAa,IAAA;IAC/C,MAAMC,gBAAA,GAAoBC,KAAO,IAAA;AAC/B,MAAA,IAAIA,KAAA,CAAMC,GAAG,KAAK,OAAW,KAACD,MAAME,OAAO,IAAIF,KAAM,CAAAG,OAAO,CAAG,EAAA;QAC7DL,WAAA,CAAYM,aAAa,EAAA;AAC3B;KACF;AACAC,IAAAA,MAAO,CAAAC,gBAAgB,CAAC,SAAW,EAAAP,gBAAA,CAAA;IACnC,OAAO,MAAMM,MAAA,CAAOE,mBAAmB,CAAC,SAAW,EAAAR,gBAAA,CAAA;AACrD,GAAG,CAAA;AAEHS,EAAAA,YAAe,GAAAX,QAAA,CAAUY,OAAS,IAAA;IAChC,IAAI,CAACC,uBAAuB,GAAGD,OAAA;AACjC,GAAG,CAAA;AAAA,EAAA;IAAAlB,CAAA,CAAA,IAAA,CAAAC,SAAA,EAAA,gBAAA,EAAA,CAEFC,OAAA,CAAA,EAAA,YAAA;AAAA,MAAA,OAAyB,KAAM;AAAA,KAAA,CAAA;AAAA;AAAA,EAAA,eAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,gBAAA,CAAA,EAAAC,MAAA;AAAA,EAAA;IAAAJ,CAAA,CAAA,IAAA,CAAAC,SAAA,EAAA,iBAAA,EAAA,CAC/BC,OAAA,CAAA,EAAA,YAAA;AAAA,MAAA,OAA0B,EAAG;AAAA,KAAA,CAAA;AAAA;AAAA,EAAA,gBAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,iBAAA,CAAA,EAAAC,MAAA;EAE9BgB,aAAA,GAAiBX,KAAO,IAAA;AACtB,IAAA,IAAI,CAACY,eAAe,GAAIZ,MAAMa,MAAM,CAAsBC,KAAK;GAC/D;EACFC,oBAAuB,GAACD,KAAe,IAAA;IACrC,IAAI,CAACE,cAAc,GAAGF,KAAA;GACtB;EAEFG,IAAA,GAAQjB,KAAO,IAAA;IACbA,KAAA,CAAMkB,cAAc,EAAA;IACpB,IAAI,IAAI,CAACC,QAAQ,EAAE;AACjB,MAAA,IAAI,CAACC,IAAI,CAACC,gBAAgB,CAAC;QAAEC,OAAS,EAAA,IAAI,CAACV;AAAgB,OAAA,CAAA;AAC7D,KAAO,MAAA;AACL,MAAA,IAAI,CAACQ,IAAI,CAACC,gBAAgB,CAAC;QAAEE,WAAa,EAAA,IAAI,CAACX;AAAgB,OAAA,CAAA;AACjE;GACA;EAEF,IAAIY,OAAUA,GAAA;AACZ,IAAA,OAAO,CAAC,CAAC,IAAI,CAACZ,eAAe;AAC/B;EACA,IAAIO,QAAWA,GAAA;AACb,IAAA,OAAO,IAAI,CAACH,cAAc,KAAK,KAAA;AACjC;AAEA,EAAA;IAAAS,oBAAA,CAAAC,kBAAA,CA+EA,g7DAAA,EAAA;MAAAC,UAAA,EAAA,IAAA;AAAAC,MAAAA,KAAA,EAAAA,OAAA;sBAAAC,qBAAA;QAAAC,OAAA;QAAAC,EAAA;QAAAC,SAAA;QAAAC,OAAA;QAAAC,YAAA;QAAAC,OAAA;QAAAC,aAAA;QAAAC,QAAA;AAAAC,QAAAA;AAAA,OAAA;KAAU,CAAA,EAAV,IAAW,CAAA;AAAD;AACZ;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"selection-tooltip.js","sources":["../../../src/components/_private/selection-tooltip.ts"],"sourcesContent":["import {\n type VirtualElement,\n flip,\n hide,\n offset,\n shift,\n type Middleware,\n} from '@floating-ui/dom';\nimport Component from '@glimmer/component';\nimport floatingUI from '#root/modifiers/_private/floating-ui.ts';\nimport type SayController from '#root/core/say-controller.ts';\n\ntype Args = {\n controller: SayController;\n visible: boolean;\n};\nexport default class SelectionTooltip extends Component<Args> {\n floatingUI = floatingUI;\n\n get controller() {\n return this.args.controller;\n }\n\n get visible() {\n return this.args.visible;\n }\n\n get referenceElement() {\n const { selection } = this.controller.mainEditorState;\n const virtualElement: VirtualElement = {\n getBoundingClientRect: () => {\n const coordsFrom = this.controller.mainEditorView.coordsAtPos(\n selection.from,\n -1,\n );\n const coordsTo = this.controller.mainEditorView.coordsAtPos(\n selection.to,\n -1,\n );\n const left = (coordsFrom.left + coordsTo.left) / 2;\n const right = (coordsFrom.right + coordsTo.right) / 2;\n const bottom = coordsTo.bottom;\n const top = coordsFrom.top;\n return {\n left,\n right,\n bottom,\n top,\n x: left,\n y: top,\n width: 0,\n height: bottom - top,\n };\n },\n contextElement: this.controller.mainEditorView.dom,\n };\n return virtualElement;\n }\n get tooltipMiddleWare(): Middleware[] {\n return [\n offset(10),\n flip(),\n shift({ padding: 5 }),\n hide({ strategy: 'referenceHidden' }),\n hide({ strategy: 'escaped' }),\n ];\n }\n}\n"],"names":["SelectionTooltip","Component","floatingUI","controller","args","visible","referenceElement","selection","mainEditorState","virtualElement","getBoundingClientRect","coordsFrom","mainEditorView","coordsAtPos","from","coordsTo","to","left","right","bottom","top","x","y","width","height","contextElement","dom","tooltipMiddleWare","offset","flip","shift","padding","hide","strategy","setComponentTemplate","TEMPLATE"],"mappings":";;;;;;;;AAgBe,MAAMA,gBAAgB,SAASC,SAAS,CAAO;AAC5DC,EAAAA,UAAU,GAAGA,UAAU;EAEvB,IAAIC,UAAUA,GAAG;AACf,IAAA,OAAO,IAAI,CAACC,IAAI,CAACD,UAAU;AAC7B;EAEA,IAAIE,OAAOA,GAAG;AACZ,IAAA,OAAO,IAAI,CAACD,IAAI,CAACC,OAAO;AAC1B;EAEA,IAAIC,gBAAgBA,GAAG;IACrB,MAAM;AAAEC,MAAAA;AAAU,KAAC,GAAG,IAAI,CAACJ,UAAU,CAACK,eAAe;AACrD,IAAA,MAAMC,cAA8B,GAAG;MACrCC,qBAAqB,EAAEA,MAAM;AAC3B,QAAA,MAAMC,UAAU,GAAG,IAAI,CAACR,UAAU,CAACS,cAAc,CAACC,WAAW,CAC3DN,SAAS,CAACO,IAAI,EACd,EACF,CAAC;AACD,QAAA,MAAMC,QAAQ,GAAG,IAAI,CAACZ,UAAU,CAACS,cAAc,CAACC,WAAW,CACzDN,SAAS,CAACS,EAAE,EACZ,EACF,CAAC;QACD,MAAMC,IAAI,GAAG,CAACN,UAAU,CAACM,IAAI,GAAGF,QAAQ,CAACE,IAAI,IAAI,CAAC;QAClD,MAAMC,KAAK,GAAG,CAACP,UAAU,CAACO,KAAK,GAAGH,QAAQ,CAACG,KAAK,IAAI,CAAC;AACrD,QAAA,MAAMC,MAAM,GAAGJ,QAAQ,CAACI,MAAM;AAC9B,QAAA,MAAMC,GAAG,GAAGT,UAAU,CAACS,GAAG;QAC1B,OAAO;UACLH,IAAI;UACJC,KAAK;UACLC,MAAM;UACNC,GAAG;AACHC,UAAAA,CAAC,EAAEJ,IAAI;AACPK,UAAAA,CAAC,EAAEF,GAAG;AACNG,UAAAA,KAAK,EAAE,CAAC;UACRC,MAAM,EAAEL,MAAM,GAAGC;SAClB;OACF;AACDK,MAAAA,cAAc,EAAE,IAAI,CAACtB,UAAU,CAACS,cAAc,CAACc;KAChD;AACD,IAAA,OAAOjB,cAAc;AACvB;EACA,IAAIkB,iBAAiBA,GAAiB;IACpC,OAAO,CACLC,MAAM,CAAC,EAAE,CAAC,EACVC,IAAI,EAAE,EACNC,KAAK,CAAC;AAAEC,MAAAA,OAAO,EAAE;KAAG,CAAC,EACrBC,IAAI,CAAC;AAAEC,MAAAA,QAAQ,EAAE;KAAmB,CAAC,EACrCD,IAAI,CAAC;AAAEC,MAAAA,QAAQ,EAAE;AAAU,KAAC,CAAC,CAC9B;AACH;AACF;AAACC,oBAAA,CAAAC,QAAA,EAnDoBnC,gBAAgB,CAAA;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"with-unique-id.js","sources":["../../../src/components/_private/with-unique-id.ts"],"sourcesContent":["/* eslint-disable ember/no-empty-glimmer-component-classes */\nimport Component from '@glimmer/component';\n\ninterface Sig {\n Blocks: {\n default: [string];\n };\n}\n\n/**\n * This is just a workaround component for the lack of availability of the\n * uniqueId helper in 4.12 template imports\n */\nexport default class WithUniqueIdComponent extends Component<Sig> {}\n"],"names":["WithUniqueIdComponent","Component","setComponentTemplate","TEMPLATE"],"mappings":";;;;;;AAAA;AASA;AACA;AACA;AACA;AACe,MAAMA,qBAAqB,SAASC,SAAS,CAAM;AAAEC,oBAAA,CAAAC,QAAA,EAA/CH,qBAAqB,CAAA;;;;"}