taggedjs 2.3.28 → 2.4.2

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 (379) hide show
  1. package/index.js +1 -1
  2. package/js/Subject.d.ts +2 -1
  3. package/js/Subject.js +11 -7
  4. package/js/Subject.js.map +1 -1
  5. package/js/Tag.class.d.ts +1 -4
  6. package/js/Tag.class.js +29 -56
  7. package/js/Tag.class.js.map +1 -1
  8. package/js/Tag.utils.d.ts +7 -3
  9. package/js/Tag.utils.js +3 -3
  10. package/js/Tag.utils.js.map +1 -1
  11. package/js/TagSupport.class.d.ts +7 -11
  12. package/js/TagSupport.class.js +21 -92
  13. package/js/TagSupport.class.js.map +1 -1
  14. package/js/ValueSubject.d.ts +1 -1
  15. package/js/ValueSubject.js +3 -3
  16. package/js/ValueSubject.js.map +1 -1
  17. package/js/bindSubjectCallback.function.d.ts +2 -1
  18. package/js/bindSubjectCallback.function.js +14 -9
  19. package/js/bindSubjectCallback.function.js.map +1 -1
  20. package/js/deepFunctions.js +9 -4
  21. package/js/deepFunctions.js.map +1 -1
  22. package/js/elementDestroyCheck.function.d.ts +3 -3
  23. package/js/elementDestroyCheck.function.js.map +1 -1
  24. package/js/elementInitCheck.d.ts +1 -1
  25. package/js/elementInitCheck.js +4 -4
  26. package/js/elementInitCheck.js.map +1 -1
  27. package/js/gateway/loadTagGateway.function.d.ts +2 -2
  28. package/js/gateway/loadTagGateway.function.js.map +1 -1
  29. package/js/gateway/tagGateway.function.d.ts +3 -2
  30. package/js/gateway/tagGateway.function.js.map +1 -1
  31. package/js/gateway/tagGateway.utils.d.ts +4 -3
  32. package/js/gateway/tagGateway.utils.js +3 -15
  33. package/js/gateway/tagGateway.utils.js.map +1 -1
  34. package/js/getCallback.js +1 -1
  35. package/js/getCallback.js.map +1 -1
  36. package/js/hasTagSupportChanged.function.d.ts +7 -0
  37. package/js/hasTagSupportChanged.function.js +76 -0
  38. package/js/hasTagSupportChanged.function.js.map +1 -0
  39. package/js/index.d.ts +4 -2
  40. package/js/index.js +5 -2
  41. package/js/index.js.map +1 -1
  42. package/js/interpolateAttributes.js +24 -16
  43. package/js/interpolateAttributes.js.map +1 -1
  44. package/js/interpolateContentTemplates.d.ts +1 -1
  45. package/js/interpolateContentTemplates.js +8 -10
  46. package/js/interpolateContentTemplates.js.map +1 -1
  47. package/js/interpolateElement.d.ts +2 -0
  48. package/js/interpolateElement.js +1 -8
  49. package/js/interpolateElement.js.map +1 -1
  50. package/js/interpolateTemplate.d.ts +3 -3
  51. package/js/interpolateTemplate.js +18 -13
  52. package/js/interpolateTemplate.js.map +1 -1
  53. package/js/onDestroy.js +0 -3
  54. package/js/onDestroy.js.map +1 -1
  55. package/js/onInit.js +0 -4
  56. package/js/onInit.js.map +1 -1
  57. package/js/processNewValue.function.d.ts +2 -0
  58. package/js/processNewValue.function.js +29 -0
  59. package/js/processNewValue.function.js.map +1 -0
  60. package/js/processRegularValue.function.d.ts +7 -0
  61. package/js/processRegularValue.function.js +21 -0
  62. package/js/processRegularValue.function.js.map +1 -0
  63. package/js/processSubjectComponent.function.js +3 -19
  64. package/js/processSubjectComponent.function.js.map +1 -1
  65. package/js/processSubjectValue.function.d.ts +6 -5
  66. package/js/processSubjectValue.function.js +28 -42
  67. package/js/processSubjectValue.function.js.map +1 -1
  68. package/js/processTagArray.d.ts +1 -0
  69. package/js/processTagArray.js +46 -16
  70. package/js/processTagArray.js.map +1 -1
  71. package/js/processTagResult.function.d.ts +1 -2
  72. package/js/processTagResult.function.js +1 -17
  73. package/js/processTagResult.function.js.map +1 -1
  74. package/js/propState.function.d.ts +2 -0
  75. package/js/propState.function.js +3 -0
  76. package/js/propState.function.js.map +1 -0
  77. package/js/provider.utils.d.ts +2 -0
  78. package/js/provider.utils.js +34 -0
  79. package/js/provider.utils.js.map +1 -0
  80. package/js/providers.d.ts +2 -1
  81. package/js/providers.js +2 -2
  82. package/js/providers.js.map +1 -1
  83. package/js/redrawTag.function.d.ts +3 -2
  84. package/js/redrawTag.function.js +2 -5
  85. package/js/redrawTag.function.js.map +1 -1
  86. package/js/set.function.d.ts +23 -0
  87. package/{_js/state.js → js/set.function.js} +60 -64
  88. package/js/set.function.js.map +1 -0
  89. package/js/setLet.function.d.ts +3 -0
  90. package/js/setLet.function.js +31 -0
  91. package/js/setLet.function.js.map +1 -0
  92. package/js/setProp.function.d.ts +3 -0
  93. package/js/setProp.function.js +34 -0
  94. package/js/setProp.function.js.map +1 -0
  95. package/js/setUse.function.d.ts +1 -1
  96. package/js/state.d.ts +7 -6
  97. package/js/state.js +14 -12
  98. package/js/state.js.map +1 -1
  99. package/js/tag.d.ts +7 -3
  100. package/js/tag.js +42 -8
  101. package/js/tag.js.map +1 -1
  102. package/js/tagElement.d.ts +2 -1
  103. package/js/tagElement.js +16 -8
  104. package/js/tagElement.js.map +1 -1
  105. package/js/templater.utils.d.ts +0 -3
  106. package/js/templater.utils.js +22 -19
  107. package/js/templater.utils.js.map +1 -1
  108. package/js/updateExistingTag.function.d.ts +1 -1
  109. package/js/updateExistingTag.function.js +3 -9
  110. package/js/updateExistingTag.function.js.map +1 -1
  111. package/js/updateExistingTagComponent.function.js +12 -13
  112. package/js/updateExistingTagComponent.function.js.map +1 -1
  113. package/js/updateExistingValue.function.d.ts +5 -3
  114. package/js/updateExistingValue.function.js +82 -53
  115. package/js/updateExistingValue.function.js.map +1 -1
  116. package/js/watch.function.d.ts +3 -0
  117. package/js/watch.function.js +19 -0
  118. package/js/watch.function.js.map +1 -0
  119. package/package.json +1 -1
  120. package/_js/Clones.type.d.ts +0 -1
  121. package/_js/Clones.type.js +0 -2
  122. package/_js/Clones.type.js.map +0 -1
  123. package/_js/ElementTarget.interface.d.ts +0 -7
  124. package/_js/ElementTarget.interface.js +0 -2
  125. package/_js/ElementTarget.interface.js.map +0 -1
  126. package/_js/ElementTargetEvent.interface.d.ts +0 -6
  127. package/_js/ElementTargetEvent.interface.js +0 -2
  128. package/_js/ElementTargetEvent.interface.js.map +0 -1
  129. package/_js/Props.d.ts +0 -1
  130. package/_js/Props.js +0 -2
  131. package/_js/Props.js.map +0 -1
  132. package/_js/Subject.d.ts +0 -17
  133. package/_js/Subject.js +0 -43
  134. package/_js/Subject.js.map +0 -1
  135. package/_js/Tag.class.d.ts +0 -69
  136. package/_js/Tag.class.js +0 -258
  137. package/_js/Tag.class.js.map +0 -1
  138. package/_js/Tag.utils.d.ts +0 -12
  139. package/_js/Tag.utils.js +0 -31
  140. package/_js/Tag.utils.js.map +0 -1
  141. package/_js/ValueSubject.d.ts +0 -6
  142. package/_js/ValueSubject.js +0 -15
  143. package/_js/ValueSubject.js.map +0 -1
  144. package/_js/bindSubjectCallback.function.d.ts +0 -5
  145. package/_js/bindSubjectCallback.function.js +0 -19
  146. package/_js/bindSubjectCallback.function.js.map +0 -1
  147. package/_js/deepFunctions.d.ts +0 -2
  148. package/_js/deepFunctions.js +0 -76
  149. package/_js/deepFunctions.js.map +0 -1
  150. package/_js/elementDestroyCheck.function.d.ts +0 -3
  151. package/_js/elementDestroyCheck.function.js +0 -17
  152. package/_js/elementDestroyCheck.function.js.map +0 -1
  153. package/_js/elementInitCheck.d.ts +0 -2
  154. package/_js/elementInitCheck.js +0 -18
  155. package/_js/elementInitCheck.js.map +0 -1
  156. package/_js/gateway/gateway.web.component.d.ts +0 -11
  157. package/_js/gateway/gateway.web.component.js +0 -20
  158. package/_js/gateway/gateway.web.component.js.map +0 -1
  159. package/_js/gateway/index.d.ts +0 -3
  160. package/_js/gateway/index.js +0 -4
  161. package/_js/gateway/index.js.map +0 -1
  162. package/_js/gateway/loadTagGateway.function.d.ts +0 -2
  163. package/_js/gateway/loadTagGateway.function.js +0 -18
  164. package/_js/gateway/loadTagGateway.function.js.map +0 -1
  165. package/_js/gateway/tagGateway.function.d.ts +0 -4
  166. package/_js/gateway/tagGateway.function.js +0 -49
  167. package/_js/gateway/tagGateway.function.js.map +0 -1
  168. package/_js/gateway/tagGateway.utils.d.ts +0 -21
  169. package/_js/gateway/tagGateway.utils.js +0 -139
  170. package/_js/gateway/tagGateway.utils.js.map +0 -1
  171. package/_js/getCallback.d.ts +0 -3
  172. package/_js/getCallback.js +0 -50
  173. package/_js/getCallback.js.map +0 -1
  174. package/_js/getTagSupport.d.ts +0 -21
  175. package/_js/getTagSupport.js +0 -110
  176. package/_js/getTagSupport.js.map +0 -1
  177. package/_js/html.d.ts +0 -2
  178. package/_js/html.js +0 -5
  179. package/_js/html.js.map +0 -1
  180. package/_js/index.d.ts +0 -20
  181. package/_js/index.js +0 -25
  182. package/_js/index.js.map +0 -1
  183. package/_js/inputAttribute.d.ts +0 -1
  184. package/_js/inputAttribute.js +0 -19
  185. package/_js/inputAttribute.js.map +0 -1
  186. package/_js/interpolateAttributes.d.ts +0 -4
  187. package/_js/interpolateAttributes.js +0 -135
  188. package/_js/interpolateAttributes.js.map +0 -1
  189. package/_js/interpolateContentTemplates.d.ts +0 -6
  190. package/_js/interpolateContentTemplates.js +0 -54
  191. package/_js/interpolateContentTemplates.js.map +0 -1
  192. package/_js/interpolateElement.d.ts +0 -9
  193. package/_js/interpolateElement.js +0 -39
  194. package/_js/interpolateElement.js.map +0 -1
  195. package/_js/interpolateTemplate.d.ts +0 -17
  196. package/_js/interpolateTemplate.js +0 -64
  197. package/_js/interpolateTemplate.js.map +0 -1
  198. package/_js/interpolations.d.ts +0 -7
  199. package/_js/interpolations.js +0 -18
  200. package/_js/interpolations.js.map +0 -1
  201. package/_js/isInstance.d.ts +0 -6
  202. package/_js/isInstance.js +0 -10
  203. package/_js/isInstance.js.map +0 -1
  204. package/_js/js/Clones.type.d.ts +0 -1
  205. package/_js/js/Clones.type.js +0 -2
  206. package/_js/js/Clones.type.js.map +0 -1
  207. package/_js/js/Props.d.ts +0 -1
  208. package/_js/js/Props.js +0 -2
  209. package/_js/js/Props.js.map +0 -1
  210. package/_js/js/Subject.d.ts +0 -17
  211. package/_js/js/Subject.js +0 -43
  212. package/_js/js/Subject.js.map +0 -1
  213. package/_js/js/Tag.class.d.ts +0 -67
  214. package/_js/js/Tag.class.js +0 -241
  215. package/_js/js/Tag.class.js.map +0 -1
  216. package/_js/js/Tag.utils.d.ts +0 -12
  217. package/_js/js/Tag.utils.js +0 -31
  218. package/_js/js/Tag.utils.js.map +0 -1
  219. package/_js/js/ValueSubject.d.ts +0 -6
  220. package/_js/js/ValueSubject.js +0 -15
  221. package/_js/js/ValueSubject.js.map +0 -1
  222. package/_js/js/bindSubjectCallback.function.d.ts +0 -5
  223. package/_js/js/bindSubjectCallback.function.js +0 -19
  224. package/_js/js/bindSubjectCallback.function.js.map +0 -1
  225. package/_js/js/deepFunctions.d.ts +0 -2
  226. package/_js/js/deepFunctions.js +0 -76
  227. package/_js/js/deepFunctions.js.map +0 -1
  228. package/_js/js/elementDestroyCheck.function.d.ts +0 -3
  229. package/_js/js/elementDestroyCheck.function.js +0 -17
  230. package/_js/js/elementDestroyCheck.function.js.map +0 -1
  231. package/_js/js/elementInitCheck.d.ts +0 -2
  232. package/_js/js/elementInitCheck.js +0 -18
  233. package/_js/js/elementInitCheck.js.map +0 -1
  234. package/_js/js/getCallback.d.ts +0 -3
  235. package/_js/js/getCallback.js +0 -50
  236. package/_js/js/getCallback.js.map +0 -1
  237. package/_js/js/getTagSupport.d.ts +0 -22
  238. package/_js/js/getTagSupport.js +0 -116
  239. package/_js/js/getTagSupport.js.map +0 -1
  240. package/_js/js/html.d.ts +0 -2
  241. package/_js/js/html.js +0 -5
  242. package/_js/js/html.js.map +0 -1
  243. package/_js/js/index.d.ts +0 -19
  244. package/_js/js/index.js +0 -24
  245. package/_js/js/index.js.map +0 -1
  246. package/_js/js/inputAttribute.d.ts +0 -1
  247. package/_js/js/inputAttribute.js +0 -19
  248. package/_js/js/inputAttribute.js.map +0 -1
  249. package/_js/js/interpolateAttributes.d.ts +0 -4
  250. package/_js/js/interpolateAttributes.js +0 -127
  251. package/_js/js/interpolateAttributes.js.map +0 -1
  252. package/_js/js/interpolateContentTemplates.d.ts +0 -5
  253. package/_js/js/interpolateContentTemplates.js +0 -57
  254. package/_js/js/interpolateContentTemplates.js.map +0 -1
  255. package/_js/js/interpolateElement.d.ts +0 -9
  256. package/_js/js/interpolateElement.js +0 -32
  257. package/_js/js/interpolateElement.js.map +0 -1
  258. package/_js/js/interpolateTemplate.d.ts +0 -17
  259. package/_js/js/interpolateTemplate.js +0 -64
  260. package/_js/js/interpolateTemplate.js.map +0 -1
  261. package/_js/js/interpolations.d.ts +0 -8
  262. package/_js/js/interpolations.js +0 -17
  263. package/_js/js/interpolations.js.map +0 -1
  264. package/_js/js/isInstance.d.ts +0 -6
  265. package/_js/js/isInstance.js +0 -10
  266. package/_js/js/isInstance.js.map +0 -1
  267. package/_js/js/onDestroy.d.ts +0 -2
  268. package/_js/js/onDestroy.js +0 -20
  269. package/_js/js/onDestroy.js.map +0 -1
  270. package/_js/js/onInit.d.ts +0 -2
  271. package/_js/js/onInit.js +0 -19
  272. package/_js/js/onInit.js.map +0 -1
  273. package/_js/js/processSubjectComponent.function.d.ts +0 -8
  274. package/_js/js/processSubjectComponent.function.js +0 -53
  275. package/_js/js/processSubjectComponent.function.js.map +0 -1
  276. package/_js/js/processSubjectValue.function.d.ts +0 -16
  277. package/_js/js/processSubjectValue.function.js +0 -122
  278. package/_js/js/processSubjectValue.function.js.map +0 -1
  279. package/_js/js/processTagArray.d.ts +0 -9
  280. package/_js/js/processTagArray.js +0 -60
  281. package/_js/js/processTagArray.js.map +0 -1
  282. package/_js/js/processTagResult.function.d.ts +0 -10
  283. package/_js/js/processTagResult.function.js +0 -42
  284. package/_js/js/processTagResult.function.js.map +0 -1
  285. package/_js/js/providers.d.ts +0 -17
  286. package/_js/js/providers.js +0 -86
  287. package/_js/js/providers.js.map +0 -1
  288. package/_js/js/redrawTag.function.d.ts +0 -7
  289. package/_js/js/redrawTag.function.js +0 -9
  290. package/_js/js/redrawTag.function.js.map +0 -1
  291. package/_js/js/render.d.ts +0 -1
  292. package/_js/js/render.js +0 -24
  293. package/_js/js/render.js.map +0 -1
  294. package/_js/js/renderAppToElement.d.ts +0 -14
  295. package/_js/js/renderAppToElement.js +0 -57
  296. package/_js/js/renderAppToElement.js.map +0 -1
  297. package/_js/js/setUse.function.d.ts +0 -23
  298. package/_js/js/setUse.function.js +0 -14
  299. package/_js/js/setUse.function.js.map +0 -1
  300. package/_js/js/state.d.ts +0 -24
  301. package/_js/js/state.js +0 -98
  302. package/_js/js/state.js.map +0 -1
  303. package/_js/js/tag.d.ts +0 -8
  304. package/_js/js/tag.js +0 -46
  305. package/_js/js/tag.js.map +0 -1
  306. package/_js/js/tagElement.d.ts +0 -14
  307. package/_js/js/tagElement.js +0 -57
  308. package/_js/js/tagElement.js.map +0 -1
  309. package/_js/js/tagGateway.function.d.ts +0 -5
  310. package/_js/js/tagGateway.function.js +0 -119
  311. package/_js/js/tagGateway.function.js.map +0 -1
  312. package/_js/js/tagRunner.d.ts +0 -6
  313. package/_js/js/tagRunner.js +0 -19
  314. package/_js/js/tagRunner.js.map +0 -1
  315. package/_js/js/templater.utils.d.ts +0 -28
  316. package/_js/js/templater.utils.js +0 -99
  317. package/_js/js/templater.utils.js.map +0 -1
  318. package/_js/js/updateTag.utils.d.ts +0 -6
  319. package/_js/js/updateTag.utils.js +0 -84
  320. package/_js/js/updateTag.utils.js.map +0 -1
  321. package/_js/js/wait.d.ts +0 -1
  322. package/_js/js/wait.js +0 -8
  323. package/_js/js/wait.js.map +0 -1
  324. package/_js/onDestroy.d.ts +0 -2
  325. package/_js/onDestroy.js +0 -20
  326. package/_js/onDestroy.js.map +0 -1
  327. package/_js/onInit.d.ts +0 -2
  328. package/_js/onInit.js +0 -19
  329. package/_js/onInit.js.map +0 -1
  330. package/_js/processSubjectComponent.function.d.ts +0 -8
  331. package/_js/processSubjectComponent.function.js +0 -53
  332. package/_js/processSubjectComponent.function.js.map +0 -1
  333. package/_js/processSubjectValue.function.d.ts +0 -16
  334. package/_js/processSubjectValue.function.js +0 -122
  335. package/_js/processSubjectValue.function.js.map +0 -1
  336. package/_js/processTagArray.d.ts +0 -9
  337. package/_js/processTagArray.js +0 -60
  338. package/_js/processTagArray.js.map +0 -1
  339. package/_js/processTagResult.function.d.ts +0 -10
  340. package/_js/processTagResult.function.js +0 -40
  341. package/_js/processTagResult.function.js.map +0 -1
  342. package/_js/providers.d.ts +0 -17
  343. package/_js/providers.js +0 -86
  344. package/_js/providers.js.map +0 -1
  345. package/_js/redrawTag.function.d.ts +0 -7
  346. package/_js/redrawTag.function.js +0 -8
  347. package/_js/redrawTag.function.js.map +0 -1
  348. package/_js/render.d.ts +0 -1
  349. package/_js/render.js +0 -17
  350. package/_js/render.js.map +0 -1
  351. package/_js/renderAppToElement.d.ts +0 -14
  352. package/_js/renderAppToElement.js +0 -57
  353. package/_js/renderAppToElement.js.map +0 -1
  354. package/_js/setUse.function.d.ts +0 -23
  355. package/_js/setUse.function.js +0 -14
  356. package/_js/setUse.function.js.map +0 -1
  357. package/_js/state.d.ts +0 -21
  358. package/_js/state.js.map +0 -1
  359. package/_js/tag.d.ts +0 -7
  360. package/_js/tag.js +0 -46
  361. package/_js/tag.js.map +0 -1
  362. package/_js/tagElement.d.ts +0 -14
  363. package/_js/tagElement.js +0 -57
  364. package/_js/tagElement.js.map +0 -1
  365. package/_js/tagGateway.function.d.ts +0 -14
  366. package/_js/tagGateway.function.js +0 -138
  367. package/_js/tagGateway.function.js.map +0 -1
  368. package/_js/tagRunner.d.ts +0 -6
  369. package/_js/tagRunner.js +0 -19
  370. package/_js/tagRunner.js.map +0 -1
  371. package/_js/templater.utils.d.ts +0 -27
  372. package/_js/templater.utils.js +0 -98
  373. package/_js/templater.utils.js.map +0 -1
  374. package/_js/updateTag.utils.d.ts +0 -6
  375. package/_js/updateTag.utils.js +0 -102
  376. package/_js/updateTag.utils.js.map +0 -1
  377. package/_js/wait.d.ts +0 -1
  378. package/_js/wait.js +0 -8
  379. package/_js/wait.js.map +0 -1
@@ -1,116 +0,0 @@
1
- import { deepClone, deepEqual } from "./deepFunctions.js";
2
- import { getNewProps } from "./templater.utils.js";
3
- /*
4
- {
5
- depth,
6
- }
7
- */
8
- export class TagSupport {
9
- templater;
10
- props;
11
- depth = 0; // TODO: maybe remove
12
- // props from **constructor** are converted for comparing over renders
13
- clonedProps;
14
- latestProps; // new props NOT cloned props
15
- latestClonedProps;
16
- memory = {
17
- context: {}, // populated after reading interpolated.values array converted to an object {variable0, variable:1}
18
- state: {
19
- newest: [],
20
- },
21
- providers: [],
22
- /** Indicator of re-rending. Saves from double rending something already rendered */
23
- renderCount: 0,
24
- };
25
- constructor(templater, props) {
26
- this.templater = templater;
27
- this.props = props;
28
- this.latestProps = props; // getNewProps(props, templater)
29
- const latestProps = getNewProps(props, templater);
30
- this.latestClonedProps = deepClone(latestProps);
31
- this.clonedProps = this.latestClonedProps;
32
- }
33
- // TODO: these below may not be in use
34
- oldest;
35
- newest;
36
- hasPropChanges(props, // natural props
37
- pastCloneProps, // previously cloned props
38
- compareToProps) {
39
- const oldProps = this.props;
40
- const isCommonEqual = props === undefined && props === compareToProps;
41
- const isEqual = isCommonEqual || deepEqual(pastCloneProps, oldProps);
42
- return !isEqual;
43
- }
44
- mutatingRender() {
45
- const message = 'Tag function "render()" was called in sync but can only be called async';
46
- console.error(message, { tagSupport: this });
47
- throw new Error(message);
48
- } // loaded later and only callable async
49
- render() {
50
- ++this.memory.renderCount;
51
- return this.mutatingRender();
52
- } // ensure this function still works even during deconstructing
53
- renderExistingTag(tag, newTemplater) {
54
- const preRenderCount = this.memory.renderCount;
55
- providersChangeCheck(tag);
56
- // When the providers were checked, a render to myself occurred and I do not need to re-render again
57
- if (preRenderCount !== this.memory.renderCount) {
58
- return true;
59
- }
60
- const oldTemplater = tag.tagSupport.templater;
61
- const nowProps = newTemplater.tagSupport.props; // natural props
62
- const oldProps = oldTemplater?.tagSupport.props; // previously cloned props
63
- const newProps = newTemplater.tagSupport.clonedProps; // new props cloned
64
- return renderTag(this, nowProps, oldProps, newProps, this.templater);
65
- }
66
- }
67
- export function getTagSupport(depth, templater, props) {
68
- const tagSupport = new TagSupport(templater, props);
69
- tagSupport.depth = depth;
70
- return tagSupport;
71
- }
72
- function providersChangeCheck(tag) {
73
- const providersWithChanges = tag.tagSupport.memory.providers.filter(provider => {
74
- return !deepEqual(provider.instance, provider.clone);
75
- });
76
- // reset clones
77
- providersWithChanges.forEach(provider => {
78
- const appElement = tag.getAppElement();
79
- handleProviderChanges(appElement, provider);
80
- provider.clone = deepClone(provider.instance);
81
- });
82
- }
83
- function handleProviderChanges(appElement, provider) {
84
- const tagsWithProvider = getTagsWithProvider(appElement, provider);
85
- tagsWithProvider.forEach(({ tag, renderCount, provider }) => {
86
- const unRendered = renderCount === tag.tagSupport.memory.renderCount;
87
- if (unRendered) {
88
- provider.clone = deepClone(provider.instance);
89
- tag.tagSupport.render();
90
- }
91
- });
92
- }
93
- function getTagsWithProvider(tag, provider, memory = []) {
94
- const hasProvider = tag.tagSupport.memory.providers.find(xProvider => xProvider.constructMethod === provider.constructMethod);
95
- if (hasProvider) {
96
- memory.push({
97
- tag,
98
- renderCount: tag.tagSupport.memory.renderCount,
99
- provider: hasProvider
100
- });
101
- }
102
- tag.children.forEach(child => getTagsWithProvider(child, provider, memory));
103
- return memory;
104
- }
105
- function renderTag(tagSupport, nowProps, // natural props
106
- oldProps, // previously NOT cloned props
107
- newProps, // now props cloned
108
- templater) {
109
- const hasPropsChanged = tagSupport.hasPropChanges(nowProps, newProps, oldProps);
110
- tagSupport.newest = templater.redraw(); // No change detected, just redraw me only
111
- if (!hasPropsChanged) {
112
- return true;
113
- }
114
- return false;
115
- }
116
- //# sourceMappingURL=getTagSupport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getTagSupport.js","sourceRoot":"","sources":["../ts/getTagSupport.ts"],"names":[],"mappings":"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"}
package/_js/js/html.d.ts DELETED
@@ -1,2 +0,0 @@
1
- import { Tag } from "./Tag.class.js";
2
- export declare function html(strings: string[] | TemplateStringsArray, ...values: unknown[]): Tag;
package/_js/js/html.js DELETED
@@ -1,5 +0,0 @@
1
- import { Tag } from "./Tag.class.js";
2
- export function html(strings, ...values) {
3
- return new Tag(strings, values);
4
- }
5
- //# sourceMappingURL=html.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"html.js","sourceRoot":"","sources":["../ts/html.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAEpC,MAAM,UAAU,IAAI,CAClB,OAAwC,EACxC,GAAG,MAAiB;IAEpB,OAAO,IAAI,GAAG,CAAC,OAAmB,EAAE,MAAM,CAAC,CAAA;AAC7C,CAAC"}
package/_js/js/index.d.ts DELETED
@@ -1,19 +0,0 @@
1
- /** Must use .js and NOT .ts extensions here */
2
- export * from "./html.js";
3
- export * from "./Subject.js";
4
- export * from "./interpolateElement.js";
5
- export * from "./getTagSupport.js";
6
- export * from "./redrawTag.function.js";
7
- export * from "./tagGateway.function.js";
8
- export { isTagComponent } from "./isInstance.js";
9
- export { tags, tag } from "./tag.js";
10
- export { TagComponent } from "./templater.utils.js";
11
- export { tagElement } from "./tagElement.js";
12
- export { Tag } from "./Tag.class.js";
13
- export { runBeforeRender } from "./tagRunner.js";
14
- export { setUse } from "./setUse.function.js";
15
- export { providers } from "./providers.js";
16
- export { state } from "./state.js";
17
- export * from "./onInit.js";
18
- export * from "./onDestroy.js";
19
- export * from "./getCallback.js";
package/_js/js/index.js DELETED
@@ -1,24 +0,0 @@
1
- /** Must use .js and NOT .ts extensions here */
2
- export * from "./html.js";
3
- export * from "./Subject.js";
4
- export * from "./interpolateElement.js";
5
- export * from "./getTagSupport.js";
6
- export * from "./redrawTag.function.js";
7
- export * from "./tagGateway.function.js";
8
- // TODO: export *
9
- export { isTagComponent } from "./isInstance.js";
10
- export { tags, tag } from "./tag.js";
11
- export { tagElement } from "./tagElement.js";
12
- export { Tag } from "./Tag.class.js";
13
- export { runBeforeRender } from "./tagRunner.js";
14
- export { setUse } from "./setUse.function.js";
15
- /* hooks */
16
- // TODO: export *
17
- export { providers } from "./providers.js";
18
- // TODO: export *
19
- export { state } from "./state.js";
20
- export * from "./onInit.js";
21
- export * from "./onDestroy.js";
22
- export * from "./getCallback.js";
23
- /* end: hooks */
24
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../ts/index.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,cAAc,WAAW,CAAA;AACzB,cAAc,cAAc,CAAA;AAC5B,cAAc,yBAAyB,CAAA;AACvC,cAAc,oBAAoB,CAAA;AAClC,cAAc,yBAAyB,CAAA;AACvC,cAAc,0BAA0B,CAAA;AAExC,iBAAiB;AACjB,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,UAAU,CAAA;AAEpC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAA;AAE7C,WAAW;AACT,iBAAiB;AACjB,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,iBAAiB;AACjB,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,cAAc,aAAa,CAAA;AAC3B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,kBAAkB,CAAA;AAClC,gBAAgB"}
@@ -1 +0,0 @@
1
- export declare function inputAttribute(name: string, value: any, element: Element): void;
@@ -1,19 +0,0 @@
1
- export function inputAttribute(name, value, element) {
2
- const names = name.split('.');
3
- // style.position = "absolute"
4
- if (names[0] === 'style') {
5
- element.style[names[1]] = value;
6
- }
7
- // Example: class.width-full = "true"
8
- if (names[0] === 'class') {
9
- names.pop();
10
- if (value) {
11
- names.forEach(name => element.classList.remove(name));
12
- }
13
- else {
14
- names.forEach(name => element.classList.add(name));
15
- }
16
- return;
17
- }
18
- }
19
- //# sourceMappingURL=inputAttribute.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"inputAttribute.js","sourceRoot":"","sources":["../ts/inputAttribute.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,cAAc,CAC5B,IAAY,EACZ,KAAU,EACV,OAAgB;IAEhB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IAE7B,8BAA8B;IAC9B,IAAG,KAAK,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE,CAAC;QACvB,OAAe,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAA;IAC1C,CAAC;IAED,qCAAqC;IACrC,IAAG,KAAK,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE,CAAC;QACxB,KAAK,CAAC,GAAG,EAAE,CAAA;QACX,IAAG,KAAK,EAAE,CAAC;YACT,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAA;QACvD,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAA;QACpD,CAAC;QACD,OAAM;IACR,CAAC;AACH,CAAC"}
@@ -1,4 +0,0 @@
1
- import { Context, Tag } from "./Tag.class.js";
2
- export declare function interpolateAttributes(child: Element, scope: Context, ownerTag: Tag): void;
3
- /** Looking for (class | style) followed by a period */
4
- export declare function isSpecialAttr(attrName: string | String): boolean;
@@ -1,127 +0,0 @@
1
- import { inputAttribute } from "./inputAttribute.js";
2
- import { isSubjectInstance } from "./isInstance.js";
3
- export function interpolateAttributes(child, scope, ownerTag) {
4
- const attrNames = child.getAttributeNames();
5
- const isTextArea = child.nodeName === 'TEXTAREA';
6
- if (isTextArea && !attrNames.includes('value')) {
7
- const value = child.getAttribute('textVarValue'); // (child as any).value
8
- processAttribute('textVarValue', value, child, scope, ownerTag, (_name, value) => child.value = value);
9
- }
10
- const howToSet = (name, value) => child.setAttribute(name, value);
11
- attrNames.forEach(attrName => {
12
- const value = child.getAttribute(attrName);
13
- processAttribute(attrName, value, child, scope, ownerTag, howToSet);
14
- });
15
- }
16
- /** Looking for (class | style) followed by a period */
17
- export function isSpecialAttr(attrName) {
18
- return attrName.search(/^(class|style)(\.)/) >= 0;
19
- }
20
- function processAttribute(attrName, value, child, scope, ownerTag, howToSet) {
21
- if (isTagVar(value)) {
22
- return processScopedNameValueAttr(attrName, value, child, scope, ownerTag, howToSet);
23
- }
24
- if (isTagVar(attrName)) {
25
- const contextValueSubject = getContextValueByVarString(scope, attrName);
26
- let lastValue;
27
- // the above callback gets called immediately since its a ValueSubject()
28
- const sub = contextValueSubject.subscribe((value) => {
29
- processNameOnlyAttr(value, lastValue, child, ownerTag, howToSet);
30
- lastValue = value;
31
- });
32
- ownerTag.cloneSubs.push(sub); // this is where unsubscribe is picked up
33
- child.removeAttribute(attrName);
34
- return;
35
- }
36
- // Non dynamic
37
- const isSpecial = isSpecialAttr(attrName);
38
- if (isSpecial) {
39
- return inputAttribute(attrName, value, child);
40
- }
41
- }
42
- const startRegX = /^\s*{__tagvar/;
43
- const endRegX = /}\s*$/;
44
- function isTagVar(value) {
45
- return value && value.search(startRegX) >= 0 && value.search(endRegX) >= 0;
46
- }
47
- function processNameOnlyAttr(attrValue, lastValue, child, ownerTag, howToSet) {
48
- if (lastValue && lastValue != attrValue) {
49
- if (typeof (lastValue) === 'string') {
50
- child.removeAttribute(lastValue);
51
- }
52
- else if (lastValue instanceof Object) {
53
- Object.entries(lastValue).forEach(([name]) => child.removeAttribute(name));
54
- }
55
- }
56
- if (typeof (lastValue) === 'string') {
57
- if (!attrValue.length) {
58
- return;
59
- }
60
- processNameValueAttr(attrValue, '', child, ownerTag, howToSet);
61
- return;
62
- }
63
- if (attrValue instanceof Object) {
64
- Object.entries(attrValue).forEach(([name, value]) => processNameValueAttr(name, value, child, ownerTag, howToSet));
65
- return;
66
- }
67
- }
68
- function getContextValueByVarString(scope, value) {
69
- const code = value.replace('{', '').split('').reverse().join('').replace('}', '').split('').reverse().join('');
70
- return scope[code];
71
- }
72
- function processNameValueAttr(attrName, result, child, ownerTag, howToSet) {
73
- const isSpecial = isSpecialAttr(attrName);
74
- // attach as callback
75
- if (result instanceof Function) {
76
- ;
77
- child[attrName] = function (...args) {
78
- return result(child, args);
79
- };
80
- return;
81
- }
82
- if (isSubjectInstance(result)) {
83
- child.removeAttribute(attrName);
84
- const callback = (newAttrValue) => processSubjectValue(newAttrValue, child, attrName, isSpecial, result, howToSet);
85
- // the above callback gets called immediately since its a ValueSubject()
86
- const sub = result.subscribe(callback);
87
- ownerTag.cloneSubs.push(sub); // this is where unsubscribe is picked up
88
- return;
89
- }
90
- howToSet(attrName, result);
91
- // child.setAttribute(attrName, result.value)
92
- return;
93
- }
94
- function processSubjectValue(newAttrValue, child, attrName, isSpecial, result, howToSet) {
95
- if (newAttrValue instanceof Function) {
96
- ;
97
- child[attrName] = function (...args) {
98
- return newAttrValue(child, args);
99
- };
100
- child[attrName].tagFunction = newAttrValue;
101
- return;
102
- }
103
- if (isSpecial) {
104
- inputAttribute(attrName, newAttrValue, child);
105
- return;
106
- }
107
- if (newAttrValue) {
108
- howToSet(attrName, newAttrValue);
109
- // child.setAttribute(attrName, newAttrValue)
110
- return;
111
- }
112
- const isDeadValue = newAttrValue === undefined || newAttrValue === false || newAttrValue === null;
113
- if (isDeadValue) {
114
- child.removeAttribute(attrName);
115
- return;
116
- }
117
- // value is 0
118
- howToSet(attrName, newAttrValue);
119
- // child.setAttribute(attrName, newAttrValue)
120
- }
121
- function processScopedNameValueAttr(attrName, value, // {__tagVarN}
122
- child, scope, ownerTag, howToSet) {
123
- // get the code inside the brackets like "variable0" or "{variable0}"
124
- const result = getContextValueByVarString(scope, value);
125
- return processNameValueAttr(attrName, result, child, ownerTag, howToSet);
126
- }
127
- //# sourceMappingURL=interpolateAttributes.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interpolateAttributes.js","sourceRoot":"","sources":["../ts/interpolateAttributes.ts"],"names":[],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- import { Clones } from "./Clones.type.js";
2
- import { Tag } from "./Tag.class.js";
3
- import { InterpolateOptions } from "./interpolateElement.js";
4
- /** Returns subscriptions[] that will need to be unsubscribed from when element is destroyed */
5
- export declare function interpolateContentTemplates(element: Element, variable: any, tag: Tag, options: InterpolateOptions): Clones;
@@ -1,57 +0,0 @@
1
- import { interpolateTemplate } from "./interpolateTemplate.js";
2
- const templateSearch = new RegExp('\\s*<template interpolate end id="__tagvar(\\d{1,4})"([^>]*)></template>(\\s*)');
3
- /** Returns subscriptions[] that will need to be unsubscribed from when element is destroyed */
4
- export function interpolateContentTemplates(element, variable, tag, options) {
5
- if (!element.children || element.tagName === 'TEMPLATE') {
6
- return []; // done
7
- }
8
- const counts = {
9
- added: 0,
10
- removed: 0,
11
- };
12
- const clones = [];
13
- const children = new Array(...element.children);
14
- if (element.tagName === 'TEXTAREA') {
15
- scanTextAreaValue(element);
16
- }
17
- children.forEach((child, index) => {
18
- const nextClones = interpolateChild(child, options, variable, tag, counts);
19
- if (child.tagName === 'TEXTAREA') {
20
- scanTextAreaValue(child);
21
- }
22
- clones.push(...nextClones);
23
- if (child.children) {
24
- const nextKids = new Array(...child.children);
25
- nextKids.forEach(subChild => {
26
- if (isRenderEndTemplate(subChild)) {
27
- interpolateChild(subChild, options, variable, tag, counts);
28
- }
29
- const nextClones = interpolateContentTemplates(subChild, variable, tag, options);
30
- clones.push(...nextClones);
31
- });
32
- }
33
- });
34
- return clones;
35
- }
36
- function interpolateChild(child, options, variable, tag, counts) {
37
- const clones = interpolateTemplate(child, variable, tag, counts, options);
38
- return clones;
39
- }
40
- function isRenderEndTemplate(child) {
41
- const isTemplate = child.tagName === 'TEMPLATE';
42
- return isTemplate &&
43
- child.getAttribute('interpolate') !== undefined &&
44
- child.getAttribute('end') !== undefined;
45
- }
46
- function scanTextAreaValue(textarea) {
47
- const value = textarea.value;
48
- if (value.search(templateSearch) >= 0) {
49
- const match = value.match(/__tagvar(\d{1,4})/);
50
- const result = match ? match[0] : '';
51
- const token = '{' + result + '}';
52
- // textarea.value = token
53
- textarea.value = '';
54
- textarea.setAttribute('textVarValue', token);
55
- }
56
- }
57
- //# sourceMappingURL=interpolateContentTemplates.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interpolateContentTemplates.js","sourceRoot":"","sources":["../ts/interpolateContentTemplates.ts"],"names":[],"mappings":"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"}
@@ -1,9 +0,0 @@
1
- import { Context, Tag } from "./Tag.class.js";
2
- import { Clones } from "./Clones.type.js";
3
- export type InterpolateOptions = {
4
- /** make the element go on document */
5
- forceElement?: boolean;
6
- depth: number;
7
- };
8
- export declare function interpolateElement(element: Element, context: Context, // variables used to evaluate
9
- tag: Tag, options: InterpolateOptions): Clones;
@@ -1,32 +0,0 @@
1
- import { interpolateAttributes } from "./interpolateAttributes.js";
2
- import { interpolateToTemplates } from "./interpolations.js";
3
- import { interpolateContentTemplates } from "./interpolateContentTemplates.js";
4
- import { escapeSearch, variablePrefix } from "./Tag.class.js";
5
- export function interpolateElement(element, context, // variables used to evaluate
6
- tag, options) {
7
- const clones = [];
8
- const result = interpolateElementChild(element, options.depth + 1);
9
- if (result.keys.length) {
10
- const nextClones = interpolateContentTemplates(element, context, tag, options);
11
- clones.push(...nextClones);
12
- }
13
- interpolateAttributes(element, context, tag);
14
- processChildrenAttributes(element.children, context, tag);
15
- return clones;
16
- }
17
- function processChildrenAttributes(children, context, ownerTag) {
18
- new Array(...children).forEach(child => {
19
- interpolateAttributes(child, context, ownerTag);
20
- if (child.children) {
21
- processChildrenAttributes(child.children, context, ownerTag);
22
- }
23
- });
24
- }
25
- /** Convert interpolations into template tags */
26
- function interpolateElementChild(child, depth) {
27
- const result = interpolateToTemplates(child.innerHTML, { depth });
28
- result.string = result.string.replace(escapeSearch, variablePrefix);
29
- child.innerHTML = result.string;
30
- return result;
31
- }
32
- //# sourceMappingURL=interpolateElement.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interpolateElement.js","sourceRoot":"","sources":["../ts/interpolateElement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAClE,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AAC5D,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAA;AAC9E,OAAO,EAAgB,YAAY,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAS3E,MAAM,UAAU,kBAAkB,CAChC,OAAgB,EAChB,OAAgB,EAAE,6BAA6B;AAC/C,GAAQ,EACR,OAA2B;IAE3B,MAAM,MAAM,GAAG,EAAE,CAAA;IACjB,MAAM,MAAM,GAAG,uBAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAA;IAElE,IAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QACtB,MAAM,UAAU,GAAG,2BAA2B,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,CAAC,CAAA;QAC9E,MAAM,CAAC,IAAI,CAAE,GAAG,UAAU,CAAE,CAAA;IAC9B,CAAC;IAED,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,CAAC,CAAA;IAC5C,yBAAyB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,CAAC,CAAA;IAEzD,OAAO,MAAM,CAAA;AACf,CAAC;AAED,SAAS,yBAAyB,CAChC,QAAwB,EACxB,OAAgB,EAChB,QAAa;IAEb,IAAI,KAAK,CAAC,GAAG,QAAe,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QAC5C,qBAAqB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;QAE/C,IAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;YAClB,yBAAyB,CAAC,KAAK,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;QAC9D,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,gDAAgD;AAChD,SAAS,uBAAuB,CAC9B,KAAc,EACd,KAAa;IAEb,MAAM,MAAM,GAAG,sBAAsB,CAAC,KAAK,CAAC,SAAS,EAAE,EAAC,KAAK,EAAC,CAAC,CAAA;IAC/D,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,EAAE,cAAc,CAAC,CAAA;IACnE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAA;IAC/B,OAAO,MAAM,CAAA;AACf,CAAC"}
@@ -1,17 +0,0 @@
1
- import { Context, ElementBuildOptions, Tag } from "./Tag.class.js";
2
- import { InterpolateOptions } from "./interpolateElement.js";
3
- import { Clones } from "./Clones.type.js";
4
- export type Template = Element & {
5
- clone: any;
6
- };
7
- export declare function interpolateTemplate(template: Template, // <template end interpolate /> (will be removed)
8
- context: Context, // variable scope of {`__tagvar${index}`:'x'}
9
- tag: Tag, // Tag class
10
- counts: Counts, // {added:0, removed:0}
11
- options: InterpolateOptions): Clones;
12
- export declare function updateBetweenTemplates(value: string | undefined | boolean | number, lastFirstChild: Element): Text;
13
- export type Counts = {
14
- added: number;
15
- removed: number;
16
- };
17
- export declare function afterElmBuild(elm: Element | ChildNode, options: ElementBuildOptions): void;
@@ -1,64 +0,0 @@
1
- import { variablePrefix } from "./Tag.class.js";
2
- import { elementInitCheck } from "./elementInitCheck.js";
3
- import { processSubjectValue } from "./processSubjectValue.function.js";
4
- export function interpolateTemplate(template, // <template end interpolate /> (will be removed)
5
- context, // variable scope of {`__tagvar${index}`:'x'}
6
- tag, // Tag class
7
- counts, // {added:0, removed:0}
8
- options) {
9
- const clones = [];
10
- if (!template.hasAttribute('end')) {
11
- return clones; // only care about starts
12
- }
13
- const variableName = template.getAttribute('id');
14
- if (variableName?.substring(0, variablePrefix.length) !== variablePrefix) {
15
- return clones; // ignore, not a tagVar
16
- }
17
- const result = context[variableName];
18
- // const isSubject = isSubjectInstance(result)
19
- let isForceElement = options.forceElement;
20
- const callback = (templateNewValue) => {
21
- const { clones } = processSubjectValue(templateNewValue, result, template, tag, { counts, forceElement: isForceElement });
22
- if (isForceElement) {
23
- isForceElement = false; // only can happen once
24
- }
25
- clones.push(...clones);
26
- // TODO: See if we can remove
27
- setTimeout(() => {
28
- counts.added = 0; // reset
29
- counts.removed = 0; // reset
30
- }, 0);
31
- };
32
- const sub = result.subscribe(callback);
33
- tag.cloneSubs.push(sub);
34
- return clones;
35
- }
36
- // Function to update the value of x
37
- export function updateBetweenTemplates(value, lastFirstChild) {
38
- const parent = lastFirstChild.parentNode;
39
- // mimic React skipping to display EXCEPT for true does display on page
40
- if (value === undefined || value === false || value === null) { // || value === true
41
- value = '';
42
- }
43
- // Insert the new value (never use innerHTML here)
44
- const textNode = document.createTextNode(value); // never innerHTML
45
- parent.insertBefore(textNode, lastFirstChild);
46
- /* remove existing nodes */
47
- parent.removeChild(lastFirstChild);
48
- if (lastFirstChild.nodeName === 'TEMPLATE') {
49
- lastFirstChild.setAttribute('removedAt', Date.now().toString());
50
- }
51
- return textNode;
52
- }
53
- export function afterElmBuild(elm, options) {
54
- if (!elm.getAttribute) {
55
- return;
56
- }
57
- if (!options.forceElement) {
58
- elementInitCheck(elm, options.counts);
59
- }
60
- if (elm.children) {
61
- new Array(...elm.children).forEach(child => afterElmBuild(child, options));
62
- }
63
- }
64
- //# sourceMappingURL=interpolateTemplate.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interpolateTemplate.js","sourceRoot":"","sources":["../ts/interpolateTemplate.ts"],"names":[],"mappings":"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"}
@@ -1,8 +0,0 @@
1
- export declare const interpolateReplace: RegExp;
2
- /** replaces ${x} with <template id="x-start"></template><template id="x-end"></template> */
3
- export declare function interpolateToTemplates(template: string, { depth }: {
4
- depth: number;
5
- }): {
6
- string: string;
7
- keys: string[];
8
- };
@@ -1,17 +0,0 @@
1
- export const interpolateReplace = /(?:<[^>]*>)|({__tagvar[^}]+})/g;
2
- /** replaces ${x} with <template id="x-start"></template><template id="x-end"></template> */
3
- export function interpolateToTemplates(template, { depth }) {
4
- const keys = [];
5
- const string = template.replace(interpolateReplace, (match, expression) => {
6
- if (match.startsWith('<')) {
7
- // If the match is an HTML tag, don't replace
8
- return match;
9
- }
10
- const noBraces = expression.substring(1, expression.length - 1);
11
- const id = noBraces;
12
- keys.push(id);
13
- return `<template interpolate end id="${id}" depth="${depth}"></template>`;
14
- });
15
- return { string, keys };
16
- }
17
- //# sourceMappingURL=interpolations.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interpolations.js","sourceRoot":"","sources":["../ts/interpolations.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,kBAAkB,GAAG,gCAAgC,CAAA;AAElE,4FAA4F;AAC5F,MAAM,UAAU,sBAAsB,CACpC,QAAgB,EAChB,EAAC,KAAK,EAAkB;IAExB,MAAM,IAAI,GAAa,EAAE,CAAA;IACzB,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;QACxE,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,6CAA6C;YAC7C,OAAO,KAAK,CAAA;QACd,CAAC;QAED,MAAM,QAAQ,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,EAAE,UAAU,CAAC,MAAM,GAAC,CAAC,CAAC,CAAA;QAC7D,MAAM,EAAE,GAAG,QAAQ,CAAA;QACnB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACb,OAAO,iCAAiC,EAAE,YAAY,KAAK,eAAe,CAAA;IAC5E,CAAC,CAAC,CAAA;IAEF,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAA;AACzB,CAAC"}
@@ -1,6 +0,0 @@
1
- import { SubjectLike } from "./Subject.js";
2
- import { Tag } from "./Tag.class.js";
3
- import { TemplaterResult } from "./templater.utils.js";
4
- export declare function isTagComponent(value?: TemplaterResult): boolean;
5
- export declare function isTagInstance(tag?: Tag | unknown): boolean;
6
- export declare function isSubjectInstance(subject?: SubjectLike): Boolean;
@@ -1,10 +0,0 @@
1
- export function isTagComponent(value) {
2
- return value?.isTemplater === true;
3
- }
4
- export function isTagInstance(tag) {
5
- return tag?.isTag === true;
6
- }
7
- export function isSubjectInstance(subject) {
8
- return (subject?.isSubject === true || subject?.subscribe) ? true : false; // subject?.isSubject === true ||
9
- }
10
- //# sourceMappingURL=isInstance.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"isInstance.js","sourceRoot":"","sources":["../ts/isInstance.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,cAAc,CAAC,KAAuB;IACpD,OAAO,KAAK,EAAE,WAAW,KAAK,IAAI,CAAA;AACpC,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,GAAmB;IAC/C,OAAQ,GAAW,EAAE,KAAK,KAAK,IAAI,CAAA;AACrC,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,OAAqB;IAErB,OAAO,CAAC,OAAO,EAAE,SAAS,KAAK,IAAI,IAAI,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA,CAAC,kCAAkC;AAC9G,CAAC"}
@@ -1,2 +0,0 @@
1
- export type OnDestroyCallback = () => unknown;
2
- export declare function onDestroy(callback: OnDestroyCallback): void;