@vived/core 1.2.2 → 1.2.3

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 (570) hide show
  1. package/dist/cjs/AppObject/AppObject.js +59 -0
  2. package/dist/cjs/AppObject/AppObject.js.map +1 -0
  3. package/dist/cjs/AppObject/AppObject.test.js +113 -0
  4. package/dist/cjs/AppObject/AppObject.test.js.map +1 -0
  5. package/dist/cjs/AppObject/AppObjectComponent.js +82 -0
  6. package/dist/cjs/AppObject/AppObjectComponent.js.map +1 -0
  7. package/dist/cjs/AppObject/AppObjectComponent.test.js +132 -0
  8. package/dist/cjs/AppObject/AppObjectComponent.test.js.map +1 -0
  9. package/dist/cjs/AppObject/AppObjectController.js +12 -0
  10. package/dist/cjs/AppObject/AppObjectController.js.map +1 -0
  11. package/dist/cjs/AppObject/AppObjectEntity.js +38 -0
  12. package/dist/cjs/AppObject/AppObjectEntity.js.map +1 -0
  13. package/dist/cjs/AppObject/AppObjectEntity.test.js +108 -0
  14. package/dist/cjs/AppObject/AppObjectEntity.test.js.map +1 -0
  15. package/dist/cjs/AppObject/AppObjectEntityRepo.js +56 -0
  16. package/dist/cjs/AppObject/AppObjectEntityRepo.js.map +1 -0
  17. package/dist/cjs/AppObject/AppObjectEntityRepo.test.js +149 -0
  18. package/dist/cjs/AppObject/AppObjectEntityRepo.test.js.map +1 -0
  19. package/dist/cjs/AppObject/AppObjectPM.js +40 -0
  20. package/dist/cjs/AppObject/AppObjectPM.js.map +1 -0
  21. package/dist/cjs/AppObject/AppObjectPM.test.js +103 -0
  22. package/dist/cjs/AppObject/AppObjectPM.test.js.map +1 -0
  23. package/dist/cjs/AppObject/AppObjectRepo.js +133 -0
  24. package/dist/cjs/AppObject/AppObjectRepo.js.map +1 -0
  25. package/dist/cjs/AppObject/AppObjectRepo.test.js +213 -0
  26. package/dist/cjs/AppObject/AppObjectRepo.test.js.map +1 -0
  27. package/dist/cjs/AppObject/AppObjectUC.js +12 -0
  28. package/dist/cjs/AppObject/AppObjectUC.js.map +1 -0
  29. package/dist/cjs/AppObject/AppObjectView.js +12 -0
  30. package/dist/cjs/AppObject/AppObjectView.js.map +1 -0
  31. package/dist/cjs/AppObject/getSingletonComponent.js +7 -0
  32. package/dist/cjs/AppObject/getSingletonComponent.js.map +1 -0
  33. package/dist/cjs/AppObject/getSingletonComponent.test.js +13 -0
  34. package/dist/cjs/AppObject/getSingletonComponent.test.js.map +1 -0
  35. package/dist/cjs/AppObject/index.js +27 -0
  36. package/dist/cjs/AppObject/index.js.map +1 -0
  37. package/dist/cjs/AppObject/printAppObjectDetails.js +18 -0
  38. package/dist/cjs/AppObject/printAppObjectDetails.js.map +1 -0
  39. package/dist/cjs/Entities/MemoizedAngle.js +23 -0
  40. package/dist/cjs/Entities/MemoizedAngle.js.map +1 -0
  41. package/dist/cjs/Entities/MemoizedAngle.test.js +30 -0
  42. package/dist/cjs/Entities/MemoizedAngle.test.js.map +1 -0
  43. package/dist/cjs/Entities/MemoizedBoolean.js +23 -0
  44. package/dist/cjs/Entities/MemoizedBoolean.js.map +1 -0
  45. package/dist/cjs/Entities/MemoizedBoolean.test.js +34 -0
  46. package/dist/cjs/Entities/MemoizedBoolean.test.js.map +1 -0
  47. package/dist/cjs/Entities/MemoizedColor.js +24 -0
  48. package/dist/cjs/Entities/MemoizedColor.js.map +1 -0
  49. package/dist/cjs/Entities/MemoizedColor.test.js +32 -0
  50. package/dist/cjs/Entities/MemoizedColor.test.js.map +1 -0
  51. package/dist/cjs/Entities/MemoizedNumber.js +23 -0
  52. package/dist/cjs/Entities/MemoizedNumber.js.map +1 -0
  53. package/dist/cjs/Entities/MemoizedNumber.test.js +29 -0
  54. package/dist/cjs/Entities/MemoizedNumber.test.js.map +1 -0
  55. package/dist/cjs/Entities/MemoizedQuaternion.js +24 -0
  56. package/dist/cjs/Entities/MemoizedQuaternion.js.map +1 -0
  57. package/dist/cjs/Entities/MemoizedQuaternion.test.js +32 -0
  58. package/dist/cjs/Entities/MemoizedQuaternion.test.js.map +1 -0
  59. package/dist/cjs/Entities/MemoizedString.js +23 -0
  60. package/dist/cjs/Entities/MemoizedString.js.map +1 -0
  61. package/dist/cjs/Entities/MemoizedString.test.js +29 -0
  62. package/dist/cjs/Entities/MemoizedString.test.js.map +1 -0
  63. package/dist/cjs/Entities/MemoizedVector2.js +24 -0
  64. package/dist/cjs/Entities/MemoizedVector2.js.map +1 -0
  65. package/dist/cjs/Entities/MemoizedVector2.test.js +32 -0
  66. package/dist/cjs/Entities/MemoizedVector2.test.js.map +1 -0
  67. package/dist/cjs/Entities/MemoizedVector3.js +24 -0
  68. package/dist/cjs/Entities/MemoizedVector3.js.map +1 -0
  69. package/dist/cjs/Entities/MemoizedVector3.test.js +32 -0
  70. package/dist/cjs/Entities/MemoizedVector3.test.js.map +1 -0
  71. package/dist/cjs/Entities/ObservableEntity.js +20 -0
  72. package/dist/cjs/Entities/ObservableEntity.js.map +1 -0
  73. package/dist/cjs/Entities/ObservableEntity.test.js +25 -0
  74. package/dist/cjs/Entities/ObservableEntity.test.js.map +1 -0
  75. package/dist/cjs/Entities/ObserverList.js +27 -0
  76. package/dist/cjs/Entities/ObserverList.js.map +1 -0
  77. package/dist/cjs/Entities/ObserverList.test.js +44 -0
  78. package/dist/cjs/Entities/ObserverList.test.js.map +1 -0
  79. package/dist/cjs/Entities/RangedNumber.js +36 -0
  80. package/dist/cjs/Entities/RangedNumber.js.map +1 -0
  81. package/dist/cjs/Entities/RangedNumber.test.js +96 -0
  82. package/dist/cjs/Entities/RangedNumber.test.js.map +1 -0
  83. package/dist/cjs/Entities/index.js +28 -0
  84. package/dist/cjs/Entities/index.js.map +1 -0
  85. package/dist/cjs/Types/AppBoundary.js +3 -0
  86. package/dist/cjs/Types/AppBoundary.js.map +1 -0
  87. package/dist/cjs/Types/EaseFn.js +3 -0
  88. package/dist/cjs/Types/EaseFn.js.map +1 -0
  89. package/dist/cjs/Types/PmAdapter.js +3 -0
  90. package/dist/cjs/Types/PmAdapter.js.map +1 -0
  91. package/dist/cjs/Types/SingletonPmAdapter.js +3 -0
  92. package/dist/cjs/Types/SingletonPmAdapter.js.map +1 -0
  93. package/dist/cjs/Types/index.js +21 -0
  94. package/dist/cjs/Types/index.js.map +1 -0
  95. package/dist/cjs/Utilities/LengthConverters.js +21 -0
  96. package/dist/cjs/Utilities/LengthConverters.js.map +1 -0
  97. package/dist/cjs/Utilities/LengthConverters.test.js +24 -0
  98. package/dist/cjs/Utilities/LengthConverters.test.js.map +1 -0
  99. package/dist/cjs/Utilities/LerpNumber.js +85 -0
  100. package/dist/cjs/Utilities/LerpNumber.js.map +1 -0
  101. package/dist/cjs/Utilities/LerpNumber.test.js +90 -0
  102. package/dist/cjs/Utilities/LerpNumber.test.js.map +1 -0
  103. package/dist/cjs/Utilities/degreesToRadians.js +7 -0
  104. package/dist/cjs/Utilities/degreesToRadians.js.map +1 -0
  105. package/dist/cjs/Utilities/degreesToRadians.test.js +9 -0
  106. package/dist/cjs/Utilities/degreesToRadians.test.js.map +1 -0
  107. package/dist/cjs/Utilities/easeFunctions.js +208 -0
  108. package/dist/cjs/Utilities/easeFunctions.js.map +1 -0
  109. package/dist/cjs/Utilities/easeFunctions.test.js +209 -0
  110. package/dist/cjs/Utilities/easeFunctions.test.js.map +1 -0
  111. package/dist/cjs/Utilities/generateUniqueID.js +8 -0
  112. package/dist/cjs/Utilities/generateUniqueID.js.map +1 -0
  113. package/dist/cjs/Utilities/index.js +22 -0
  114. package/dist/cjs/Utilities/index.js.map +1 -0
  115. package/dist/cjs/Utilities/interpolateNumber.js +18 -0
  116. package/dist/cjs/Utilities/interpolateNumber.js.map +1 -0
  117. package/dist/cjs/Utilities/interpolateNumber.test.js +26 -0
  118. package/dist/cjs/Utilities/interpolateNumber.test.js.map +1 -0
  119. package/dist/cjs/ValueObjects/Angle.js +47 -0
  120. package/dist/cjs/ValueObjects/Angle.js.map +1 -0
  121. package/dist/cjs/ValueObjects/Angle.test.js +28 -0
  122. package/dist/cjs/ValueObjects/Angle.test.js.map +1 -0
  123. package/dist/cjs/ValueObjects/Color.js +859 -0
  124. package/dist/cjs/ValueObjects/Color.js.map +1 -0
  125. package/dist/cjs/ValueObjects/Color.test.js +147 -0
  126. package/dist/cjs/ValueObjects/Color.test.js.map +1 -0
  127. package/dist/cjs/ValueObjects/LineSegment2D.js +72 -0
  128. package/dist/cjs/ValueObjects/LineSegment2D.js.map +1 -0
  129. package/dist/cjs/ValueObjects/LineSegment2D.test.js +102 -0
  130. package/dist/cjs/ValueObjects/LineSegment2D.test.js.map +1 -0
  131. package/dist/cjs/ValueObjects/Matrix.js +466 -0
  132. package/dist/cjs/ValueObjects/Matrix.js.map +1 -0
  133. package/dist/cjs/ValueObjects/Matrix.test.js +385 -0
  134. package/dist/cjs/ValueObjects/Matrix.test.js.map +1 -0
  135. package/dist/cjs/ValueObjects/ParametricLine.js +77 -0
  136. package/dist/cjs/ValueObjects/ParametricLine.js.map +1 -0
  137. package/dist/cjs/ValueObjects/ParametricLine.test.js +126 -0
  138. package/dist/cjs/ValueObjects/ParametricLine.test.js.map +1 -0
  139. package/dist/cjs/ValueObjects/ParametricPlane.js +65 -0
  140. package/dist/cjs/ValueObjects/ParametricPlane.js.map +1 -0
  141. package/dist/cjs/ValueObjects/ParametricPlane.test.js +101 -0
  142. package/dist/cjs/ValueObjects/ParametricPlane.test.js.map +1 -0
  143. package/dist/cjs/ValueObjects/Quaternion.js +290 -0
  144. package/dist/cjs/ValueObjects/Quaternion.js.map +1 -0
  145. package/dist/cjs/ValueObjects/Quaternion.test.js +240 -0
  146. package/dist/cjs/ValueObjects/Quaternion.test.js.map +1 -0
  147. package/dist/cjs/ValueObjects/Rectangle.js +24 -0
  148. package/dist/cjs/ValueObjects/Rectangle.js.map +1 -0
  149. package/dist/cjs/ValueObjects/Rectangle.test.js +32 -0
  150. package/dist/cjs/ValueObjects/Rectangle.test.js.map +1 -0
  151. package/dist/cjs/ValueObjects/Vector2.js +184 -0
  152. package/dist/cjs/ValueObjects/Vector2.js.map +1 -0
  153. package/dist/cjs/ValueObjects/Vector2.test.js +136 -0
  154. package/dist/cjs/ValueObjects/Vector2.test.js.map +1 -0
  155. package/dist/cjs/ValueObjects/Vector3.js +231 -0
  156. package/dist/cjs/ValueObjects/Vector3.js.map +1 -0
  157. package/dist/cjs/ValueObjects/Vector3.test.js +188 -0
  158. package/dist/cjs/ValueObjects/Vector3.test.js.map +1 -0
  159. package/dist/cjs/ValueObjects/index.js +27 -0
  160. package/dist/cjs/ValueObjects/index.js.map +1 -0
  161. package/dist/cjs/index.js +22 -0
  162. package/dist/cjs/index.js.map +1 -0
  163. package/dist/esm/AppObject/AppObject.js +54 -0
  164. package/dist/esm/AppObject/AppObject.js.map +1 -0
  165. package/dist/esm/AppObject/AppObject.test.js +110 -0
  166. package/dist/esm/AppObject/AppObject.test.js.map +1 -0
  167. package/dist/esm/AppObject/AppObjectComponent.js +78 -0
  168. package/dist/esm/AppObject/AppObjectComponent.js.map +1 -0
  169. package/dist/esm/AppObject/AppObjectComponent.test.js +130 -0
  170. package/dist/esm/AppObject/AppObjectComponent.test.js.map +1 -0
  171. package/dist/esm/AppObject/AppObjectController.js +8 -0
  172. package/dist/esm/AppObject/AppObjectController.js.map +1 -0
  173. package/dist/esm/AppObject/AppObjectEntity.js +34 -0
  174. package/dist/esm/AppObject/AppObjectEntity.js.map +1 -0
  175. package/dist/esm/AppObject/AppObjectEntity.test.js +106 -0
  176. package/dist/esm/AppObject/AppObjectEntity.test.js.map +1 -0
  177. package/dist/esm/AppObject/AppObjectEntityRepo.js +52 -0
  178. package/dist/esm/AppObject/AppObjectEntityRepo.js.map +1 -0
  179. package/dist/esm/AppObject/AppObjectEntityRepo.test.js +147 -0
  180. package/dist/esm/AppObject/AppObjectEntityRepo.test.js.map +1 -0
  181. package/dist/esm/AppObject/AppObjectPM.js +36 -0
  182. package/dist/esm/AppObject/AppObjectPM.js.map +1 -0
  183. package/dist/esm/AppObject/AppObjectPM.test.js +101 -0
  184. package/dist/esm/AppObject/AppObjectPM.test.js.map +1 -0
  185. package/dist/esm/AppObject/AppObjectRepo.js +128 -0
  186. package/dist/esm/AppObject/AppObjectRepo.js.map +1 -0
  187. package/dist/esm/AppObject/AppObjectRepo.test.js +211 -0
  188. package/dist/esm/AppObject/AppObjectRepo.test.js.map +1 -0
  189. package/dist/esm/AppObject/AppObjectUC.js +8 -0
  190. package/dist/esm/AppObject/AppObjectUC.js.map +1 -0
  191. package/dist/esm/AppObject/AppObjectView.js +8 -0
  192. package/dist/esm/AppObject/AppObjectView.js.map +1 -0
  193. package/dist/esm/AppObject/getSingletonComponent.js +4 -0
  194. package/dist/esm/AppObject/getSingletonComponent.js.map +1 -0
  195. package/dist/esm/AppObject/getSingletonComponent.test.js +11 -0
  196. package/dist/esm/AppObject/getSingletonComponent.test.js.map +1 -0
  197. package/dist/esm/AppObject/index.js +11 -0
  198. package/dist/esm/AppObject/index.js.map +1 -0
  199. package/dist/esm/AppObject/printAppObjectDetails.js +15 -0
  200. package/dist/esm/AppObject/printAppObjectDetails.js.map +1 -0
  201. package/dist/esm/Entities/MemoizedAngle.js +19 -0
  202. package/dist/esm/Entities/MemoizedAngle.js.map +1 -0
  203. package/dist/esm/Entities/MemoizedAngle.test.js +28 -0
  204. package/dist/esm/Entities/MemoizedAngle.test.js.map +1 -0
  205. package/dist/esm/Entities/MemoizedBoolean.js +19 -0
  206. package/dist/esm/Entities/MemoizedBoolean.js.map +1 -0
  207. package/dist/esm/Entities/MemoizedBoolean.test.js +32 -0
  208. package/dist/esm/Entities/MemoizedBoolean.test.js.map +1 -0
  209. package/dist/esm/Entities/MemoizedColor.js +20 -0
  210. package/dist/esm/Entities/MemoizedColor.js.map +1 -0
  211. package/dist/esm/Entities/MemoizedColor.test.js +30 -0
  212. package/dist/esm/Entities/MemoizedColor.test.js.map +1 -0
  213. package/dist/esm/Entities/MemoizedNumber.js +19 -0
  214. package/dist/esm/Entities/MemoizedNumber.js.map +1 -0
  215. package/dist/esm/Entities/MemoizedNumber.test.js +27 -0
  216. package/dist/esm/Entities/MemoizedNumber.test.js.map +1 -0
  217. package/dist/esm/Entities/MemoizedQuaternion.js +20 -0
  218. package/dist/esm/Entities/MemoizedQuaternion.js.map +1 -0
  219. package/dist/esm/Entities/MemoizedQuaternion.test.js +30 -0
  220. package/dist/esm/Entities/MemoizedQuaternion.test.js.map +1 -0
  221. package/dist/esm/Entities/MemoizedString.js +19 -0
  222. package/dist/esm/Entities/MemoizedString.js.map +1 -0
  223. package/dist/esm/Entities/MemoizedString.test.js +27 -0
  224. package/dist/esm/Entities/MemoizedString.test.js.map +1 -0
  225. package/dist/esm/Entities/MemoizedVector2.js +20 -0
  226. package/dist/esm/Entities/MemoizedVector2.js.map +1 -0
  227. package/dist/esm/Entities/MemoizedVector2.test.js +30 -0
  228. package/dist/esm/Entities/MemoizedVector2.test.js.map +1 -0
  229. package/dist/esm/Entities/MemoizedVector3.js +20 -0
  230. package/dist/esm/Entities/MemoizedVector3.js.map +1 -0
  231. package/dist/esm/Entities/MemoizedVector3.test.js +30 -0
  232. package/dist/esm/Entities/MemoizedVector3.test.js.map +1 -0
  233. package/dist/esm/Entities/ObservableEntity.js +16 -0
  234. package/dist/esm/Entities/ObservableEntity.js.map +1 -0
  235. package/dist/esm/Entities/ObservableEntity.test.js +23 -0
  236. package/dist/esm/Entities/ObservableEntity.test.js.map +1 -0
  237. package/dist/esm/Entities/ObserverList.js +23 -0
  238. package/dist/esm/Entities/ObserverList.js.map +1 -0
  239. package/dist/esm/Entities/ObserverList.test.js +42 -0
  240. package/dist/esm/Entities/ObserverList.test.js.map +1 -0
  241. package/dist/esm/Entities/RangedNumber.js +32 -0
  242. package/dist/esm/Entities/RangedNumber.js.map +1 -0
  243. package/dist/esm/Entities/RangedNumber.test.js +94 -0
  244. package/dist/esm/Entities/RangedNumber.test.js.map +1 -0
  245. package/{src/Entities/index.ts → dist/esm/Entities/index.js} +12 -11
  246. package/dist/esm/Entities/index.js.map +1 -0
  247. package/dist/esm/Types/AppBoundary.js +2 -0
  248. package/dist/esm/Types/AppBoundary.js.map +1 -0
  249. package/dist/esm/Types/EaseFn.js +2 -0
  250. package/dist/esm/Types/EaseFn.js.map +1 -0
  251. package/dist/esm/Types/PmAdapter.js +2 -0
  252. package/dist/esm/Types/PmAdapter.js.map +1 -0
  253. package/dist/esm/Types/SingletonPmAdapter.js +2 -0
  254. package/dist/esm/Types/SingletonPmAdapter.js.map +1 -0
  255. package/{src/Types/index.ts → dist/esm/Types/index.js} +5 -4
  256. package/dist/esm/Types/index.js.map +1 -0
  257. package/dist/esm/Utilities/LengthConverters.js +15 -0
  258. package/dist/esm/Utilities/LengthConverters.js.map +1 -0
  259. package/dist/esm/Utilities/LengthConverters.test.js +22 -0
  260. package/dist/esm/Utilities/LengthConverters.test.js.map +1 -0
  261. package/dist/esm/Utilities/LerpNumber.js +81 -0
  262. package/dist/esm/Utilities/LerpNumber.js.map +1 -0
  263. package/dist/esm/Utilities/LerpNumber.test.js +88 -0
  264. package/dist/esm/Utilities/LerpNumber.test.js.map +1 -0
  265. package/dist/esm/Utilities/degreesToRadians.js +4 -0
  266. package/dist/esm/Utilities/degreesToRadians.js.map +1 -0
  267. package/dist/esm/Utilities/degreesToRadians.test.js +7 -0
  268. package/dist/esm/Utilities/degreesToRadians.test.js.map +1 -0
  269. package/dist/esm/Utilities/easeFunctions.js +183 -0
  270. package/dist/esm/Utilities/easeFunctions.js.map +1 -0
  271. package/dist/esm/Utilities/easeFunctions.test.js +207 -0
  272. package/dist/esm/Utilities/easeFunctions.test.js.map +1 -0
  273. package/dist/esm/Utilities/generateUniqueID.js +5 -0
  274. package/dist/esm/Utilities/generateUniqueID.js.map +1 -0
  275. package/{src/Utilities/index.ts → dist/esm/Utilities/index.js} +6 -6
  276. package/dist/esm/Utilities/index.js.map +1 -0
  277. package/dist/esm/Utilities/interpolateNumber.js +15 -0
  278. package/dist/esm/Utilities/interpolateNumber.js.map +1 -0
  279. package/dist/esm/Utilities/interpolateNumber.test.js +24 -0
  280. package/dist/esm/Utilities/interpolateNumber.test.js.map +1 -0
  281. package/dist/esm/ValueObjects/Angle.js +43 -0
  282. package/dist/esm/ValueObjects/Angle.js.map +1 -0
  283. package/dist/esm/ValueObjects/Angle.test.js +26 -0
  284. package/dist/esm/ValueObjects/Angle.test.js.map +1 -0
  285. package/dist/esm/ValueObjects/Color.js +855 -0
  286. package/dist/esm/ValueObjects/Color.js.map +1 -0
  287. package/dist/esm/ValueObjects/Color.test.js +145 -0
  288. package/dist/esm/ValueObjects/Color.test.js.map +1 -0
  289. package/dist/esm/ValueObjects/LineSegment2D.js +68 -0
  290. package/dist/esm/ValueObjects/LineSegment2D.js.map +1 -0
  291. package/dist/esm/ValueObjects/LineSegment2D.test.js +100 -0
  292. package/dist/esm/ValueObjects/LineSegment2D.test.js.map +1 -0
  293. package/dist/esm/ValueObjects/Matrix.js +462 -0
  294. package/dist/esm/ValueObjects/Matrix.js.map +1 -0
  295. package/dist/esm/ValueObjects/Matrix.test.js +383 -0
  296. package/dist/esm/ValueObjects/Matrix.test.js.map +1 -0
  297. package/dist/esm/ValueObjects/ParametricLine.js +73 -0
  298. package/dist/esm/ValueObjects/ParametricLine.js.map +1 -0
  299. package/dist/esm/ValueObjects/ParametricLine.test.js +124 -0
  300. package/dist/esm/ValueObjects/ParametricLine.test.js.map +1 -0
  301. package/dist/esm/ValueObjects/ParametricPlane.js +61 -0
  302. package/dist/esm/ValueObjects/ParametricPlane.js.map +1 -0
  303. package/dist/esm/ValueObjects/ParametricPlane.test.js +99 -0
  304. package/dist/esm/ValueObjects/ParametricPlane.test.js.map +1 -0
  305. package/dist/esm/ValueObjects/Quaternion.js +286 -0
  306. package/dist/esm/ValueObjects/Quaternion.js.map +1 -0
  307. package/dist/esm/ValueObjects/Quaternion.test.js +238 -0
  308. package/dist/esm/ValueObjects/Quaternion.test.js.map +1 -0
  309. package/dist/esm/ValueObjects/Rectangle.js +20 -0
  310. package/dist/esm/ValueObjects/Rectangle.js.map +1 -0
  311. package/dist/esm/ValueObjects/Rectangle.test.js +30 -0
  312. package/dist/esm/ValueObjects/Rectangle.test.js.map +1 -0
  313. package/dist/esm/ValueObjects/Vector2.js +180 -0
  314. package/dist/esm/ValueObjects/Vector2.js.map +1 -0
  315. package/dist/esm/ValueObjects/Vector2.test.js +134 -0
  316. package/dist/esm/ValueObjects/Vector2.test.js.map +1 -0
  317. package/dist/esm/ValueObjects/Vector3.js +227 -0
  318. package/dist/esm/ValueObjects/Vector3.js.map +1 -0
  319. package/dist/esm/ValueObjects/Vector3.test.js +186 -0
  320. package/dist/esm/ValueObjects/Vector3.test.js.map +1 -0
  321. package/{src/ValueObjects/index.ts → dist/esm/ValueObjects/index.js} +11 -14
  322. package/dist/esm/ValueObjects/index.js.map +1 -0
  323. package/{src/index.ts → dist/esm/index.js} +6 -5
  324. package/dist/esm/index.js.map +1 -0
  325. package/dist/types/AppObject/AppObject.d.ts +15 -0
  326. package/dist/types/AppObject/AppObject.d.ts.map +1 -0
  327. package/dist/types/AppObject/AppObject.test.d.ts +7 -0
  328. package/dist/types/AppObject/AppObject.test.d.ts.map +1 -0
  329. package/dist/types/AppObject/AppObjectComponent.d.ts +26 -0
  330. package/dist/types/AppObject/AppObjectComponent.d.ts.map +1 -0
  331. package/dist/types/AppObject/AppObjectComponent.test.d.ts +2 -0
  332. package/dist/types/AppObject/AppObjectComponent.test.d.ts.map +1 -0
  333. package/dist/types/AppObject/AppObjectController.d.ts +5 -0
  334. package/dist/types/AppObject/AppObjectController.d.ts.map +1 -0
  335. package/dist/types/AppObject/AppObjectEntity.d.ts +16 -0
  336. package/dist/types/AppObject/AppObjectEntity.d.ts.map +1 -0
  337. package/dist/types/AppObject/AppObjectEntity.test.d.ts +2 -0
  338. package/dist/types/AppObject/AppObjectEntity.test.d.ts.map +1 -0
  339. package/dist/types/AppObject/AppObjectEntityRepo.d.ts +16 -0
  340. package/dist/types/AppObject/AppObjectEntityRepo.d.ts.map +1 -0
  341. package/dist/types/AppObject/AppObjectEntityRepo.test.d.ts +2 -0
  342. package/dist/types/AppObject/AppObjectEntityRepo.test.d.ts.map +1 -0
  343. package/dist/types/AppObject/AppObjectPM.d.ts +13 -0
  344. package/dist/types/AppObject/AppObjectPM.d.ts.map +1 -0
  345. package/dist/types/AppObject/AppObjectPM.test.d.ts +2 -0
  346. package/dist/types/AppObject/AppObjectPM.test.d.ts.map +1 -0
  347. package/dist/types/AppObject/AppObjectRepo.d.ts +26 -0
  348. package/dist/types/AppObject/AppObjectRepo.d.ts.map +1 -0
  349. package/dist/types/AppObject/AppObjectRepo.test.d.ts +2 -0
  350. package/dist/types/AppObject/AppObjectRepo.test.d.ts.map +1 -0
  351. package/dist/types/AppObject/AppObjectUC.d.ts +5 -0
  352. package/dist/types/AppObject/AppObjectUC.d.ts.map +1 -0
  353. package/dist/types/AppObject/AppObjectView.d.ts +5 -0
  354. package/dist/types/AppObject/AppObjectView.d.ts.map +1 -0
  355. package/dist/types/AppObject/getSingletonComponent.d.ts +4 -0
  356. package/dist/types/AppObject/getSingletonComponent.d.ts.map +1 -0
  357. package/dist/types/AppObject/getSingletonComponent.test.d.ts +2 -0
  358. package/dist/types/AppObject/getSingletonComponent.test.d.ts.map +1 -0
  359. package/dist/types/AppObject/index.d.ts +11 -0
  360. package/dist/types/AppObject/index.d.ts.map +1 -0
  361. package/dist/types/AppObject/printAppObjectDetails.d.ts +3 -0
  362. package/dist/types/AppObject/printAppObjectDetails.d.ts.map +1 -0
  363. package/dist/types/Entities/MemoizedAngle.d.ts +10 -0
  364. package/dist/types/Entities/MemoizedAngle.d.ts.map +1 -0
  365. package/dist/types/Entities/MemoizedAngle.test.d.ts +2 -0
  366. package/dist/types/Entities/MemoizedAngle.test.d.ts.map +1 -0
  367. package/dist/types/Entities/MemoizedBoolean.d.ts +9 -0
  368. package/dist/types/Entities/MemoizedBoolean.d.ts.map +1 -0
  369. package/dist/types/Entities/MemoizedBoolean.test.d.ts +2 -0
  370. package/dist/types/Entities/MemoizedBoolean.test.d.ts.map +1 -0
  371. package/dist/types/Entities/MemoizedColor.d.ts +10 -0
  372. package/dist/types/Entities/MemoizedColor.d.ts.map +1 -0
  373. package/dist/types/Entities/MemoizedColor.test.d.ts +2 -0
  374. package/dist/types/Entities/MemoizedColor.test.d.ts.map +1 -0
  375. package/dist/types/Entities/MemoizedNumber.d.ts +9 -0
  376. package/dist/types/Entities/MemoizedNumber.d.ts.map +1 -0
  377. package/dist/types/Entities/MemoizedNumber.test.d.ts +2 -0
  378. package/dist/types/Entities/MemoizedNumber.test.d.ts.map +1 -0
  379. package/dist/types/Entities/MemoizedQuaternion.d.ts +10 -0
  380. package/dist/types/Entities/MemoizedQuaternion.d.ts.map +1 -0
  381. package/dist/types/Entities/MemoizedQuaternion.test.d.ts +2 -0
  382. package/dist/types/Entities/MemoizedQuaternion.test.d.ts.map +1 -0
  383. package/dist/types/Entities/MemoizedString.d.ts +9 -0
  384. package/dist/types/Entities/MemoizedString.d.ts.map +1 -0
  385. package/dist/types/Entities/MemoizedString.test.d.ts +2 -0
  386. package/dist/types/Entities/MemoizedString.test.d.ts.map +1 -0
  387. package/dist/types/Entities/MemoizedVector2.d.ts +10 -0
  388. package/dist/types/Entities/MemoizedVector2.d.ts.map +1 -0
  389. package/dist/types/Entities/MemoizedVector2.test.d.ts +2 -0
  390. package/dist/types/Entities/MemoizedVector2.test.d.ts.map +1 -0
  391. package/dist/types/Entities/MemoizedVector3.d.ts +10 -0
  392. package/dist/types/Entities/MemoizedVector3.d.ts.map +1 -0
  393. package/dist/types/Entities/MemoizedVector3.test.d.ts +2 -0
  394. package/dist/types/Entities/MemoizedVector3.test.d.ts.map +1 -0
  395. package/dist/types/Entities/ObservableEntity.d.ts +8 -0
  396. package/dist/types/Entities/ObservableEntity.d.ts.map +1 -0
  397. package/dist/types/Entities/ObservableEntity.test.d.ts +2 -0
  398. package/dist/types/Entities/ObservableEntity.test.d.ts.map +1 -0
  399. package/dist/types/Entities/ObserverList.d.ts +8 -0
  400. package/dist/types/Entities/ObserverList.d.ts.map +1 -0
  401. package/dist/types/Entities/ObserverList.test.d.ts +2 -0
  402. package/dist/types/Entities/ObserverList.test.d.ts.map +1 -0
  403. package/dist/types/Entities/RangedNumber.d.ts +17 -0
  404. package/dist/types/Entities/RangedNumber.d.ts.map +1 -0
  405. package/dist/types/Entities/RangedNumber.test.d.ts +2 -0
  406. package/dist/types/Entities/RangedNumber.test.d.ts.map +1 -0
  407. package/dist/types/Entities/index.d.ts +12 -0
  408. package/dist/types/Entities/index.d.ts.map +1 -0
  409. package/dist/types/Types/AppBoundary.d.ts +11 -0
  410. package/dist/types/Types/AppBoundary.d.ts.map +1 -0
  411. package/dist/types/Types/EaseFn.d.ts +2 -0
  412. package/dist/types/Types/EaseFn.d.ts.map +1 -0
  413. package/dist/types/Types/PmAdapter.d.ts +7 -0
  414. package/dist/types/Types/PmAdapter.d.ts.map +1 -0
  415. package/dist/types/Types/SingletonPmAdapter.d.ts +7 -0
  416. package/dist/types/Types/SingletonPmAdapter.d.ts.map +1 -0
  417. package/dist/types/Types/index.d.ts +5 -0
  418. package/dist/types/Types/index.d.ts.map +1 -0
  419. package/dist/types/Utilities/LengthConverters.d.ts +5 -0
  420. package/dist/types/Utilities/LengthConverters.d.ts.map +1 -0
  421. package/dist/types/Utilities/LengthConverters.test.d.ts +2 -0
  422. package/dist/types/Utilities/LengthConverters.test.d.ts.map +1 -0
  423. package/dist/types/Utilities/LerpNumber.d.ts +57 -0
  424. package/dist/types/Utilities/LerpNumber.d.ts.map +1 -0
  425. package/dist/types/Utilities/LerpNumber.test.d.ts +2 -0
  426. package/dist/types/Utilities/LerpNumber.test.d.ts.map +1 -0
  427. package/dist/types/Utilities/degreesToRadians.d.ts +2 -0
  428. package/dist/types/Utilities/degreesToRadians.d.ts.map +1 -0
  429. package/dist/types/Utilities/degreesToRadians.test.d.ts +2 -0
  430. package/dist/types/Utilities/degreesToRadians.test.d.ts.map +1 -0
  431. package/dist/types/Utilities/easeFunctions.d.ts +24 -0
  432. package/dist/types/Utilities/easeFunctions.d.ts.map +1 -0
  433. package/dist/types/Utilities/easeFunctions.test.d.ts +2 -0
  434. package/dist/types/Utilities/easeFunctions.test.d.ts.map +1 -0
  435. package/dist/types/Utilities/generateUniqueID.d.ts +2 -0
  436. package/dist/types/Utilities/generateUniqueID.d.ts.map +1 -0
  437. package/dist/types/Utilities/index.d.ts +6 -0
  438. package/dist/types/Utilities/index.d.ts.map +1 -0
  439. package/dist/types/Utilities/interpolateNumber.d.ts +2 -0
  440. package/dist/types/Utilities/interpolateNumber.d.ts.map +1 -0
  441. package/dist/types/Utilities/interpolateNumber.test.d.ts +2 -0
  442. package/dist/types/Utilities/interpolateNumber.test.d.ts.map +1 -0
  443. package/dist/types/ValueObjects/Angle.d.ts +27 -0
  444. package/dist/types/ValueObjects/Angle.d.ts.map +1 -0
  445. package/dist/types/ValueObjects/Angle.test.d.ts +2 -0
  446. package/dist/types/ValueObjects/Angle.test.d.ts.map +1 -0
  447. package/dist/types/ValueObjects/Color.d.ts +83 -0
  448. package/dist/types/ValueObjects/Color.d.ts.map +1 -0
  449. package/dist/types/ValueObjects/Color.test.d.ts +2 -0
  450. package/dist/types/ValueObjects/Color.test.d.ts.map +1 -0
  451. package/dist/types/ValueObjects/LineSegment2D.d.ts +12 -0
  452. package/dist/types/ValueObjects/LineSegment2D.d.ts.map +1 -0
  453. package/dist/types/ValueObjects/LineSegment2D.test.d.ts +2 -0
  454. package/dist/types/ValueObjects/LineSegment2D.test.d.ts.map +1 -0
  455. package/dist/types/ValueObjects/Matrix.d.ts +124 -0
  456. package/dist/types/ValueObjects/Matrix.d.ts.map +1 -0
  457. package/dist/types/ValueObjects/Matrix.test.d.ts +2 -0
  458. package/dist/types/ValueObjects/Matrix.test.d.ts.map +1 -0
  459. package/dist/types/ValueObjects/ParametricLine.d.ts +31 -0
  460. package/dist/types/ValueObjects/ParametricLine.d.ts.map +1 -0
  461. package/dist/types/ValueObjects/ParametricLine.test.d.ts +2 -0
  462. package/dist/types/ValueObjects/ParametricLine.test.d.ts.map +1 -0
  463. package/dist/types/ValueObjects/ParametricPlane.d.ts +21 -0
  464. package/dist/types/ValueObjects/ParametricPlane.d.ts.map +1 -0
  465. package/dist/types/ValueObjects/ParametricPlane.test.d.ts +2 -0
  466. package/dist/types/ValueObjects/ParametricPlane.test.d.ts.map +1 -0
  467. package/dist/types/ValueObjects/Quaternion.d.ts +113 -0
  468. package/dist/types/ValueObjects/Quaternion.d.ts.map +1 -0
  469. package/dist/types/ValueObjects/Quaternion.test.d.ts +2 -0
  470. package/dist/types/ValueObjects/Quaternion.test.d.ts.map +1 -0
  471. package/dist/types/ValueObjects/Rectangle.d.ts +16 -0
  472. package/dist/types/ValueObjects/Rectangle.d.ts.map +1 -0
  473. package/dist/types/ValueObjects/Rectangle.test.d.ts +2 -0
  474. package/dist/types/ValueObjects/Rectangle.test.d.ts.map +1 -0
  475. package/dist/types/ValueObjects/Vector2.d.ts +121 -0
  476. package/dist/types/ValueObjects/Vector2.d.ts.map +1 -0
  477. package/dist/types/ValueObjects/Vector2.test.d.ts +2 -0
  478. package/dist/types/ValueObjects/Vector2.test.d.ts.map +1 -0
  479. package/dist/types/ValueObjects/Vector3.d.ts +150 -0
  480. package/dist/types/ValueObjects/Vector3.d.ts.map +1 -0
  481. package/dist/types/ValueObjects/Vector3.test.d.ts +2 -0
  482. package/dist/types/ValueObjects/Vector3.test.d.ts.map +1 -0
  483. package/dist/types/ValueObjects/index.d.ts +11 -0
  484. package/dist/types/ValueObjects/index.d.ts.map +1 -0
  485. package/dist/types/index.d.ts +6 -0
  486. package/dist/types/index.d.ts.map +1 -0
  487. package/package.json +5 -2
  488. package/babel.config.js +0 -12
  489. package/jestconfig.json +0 -10
  490. package/src/AppObject/AppObject.test.ts +0 -158
  491. package/src/AppObject/AppObject.ts +0 -83
  492. package/src/AppObject/AppObjectComponent.test.ts +0 -219
  493. package/src/AppObject/AppObjectComponent.ts +0 -100
  494. package/src/AppObject/AppObjectController.ts +0 -8
  495. package/src/AppObject/AppObjectEntity.test.ts +0 -151
  496. package/src/AppObject/AppObjectEntity.ts +0 -45
  497. package/src/AppObject/AppObjectEntityRepo.test.ts +0 -211
  498. package/src/AppObject/AppObjectEntityRepo.ts +0 -61
  499. package/src/AppObject/AppObjectPM.test.ts +0 -152
  500. package/src/AppObject/AppObjectPM.ts +0 -43
  501. package/src/AppObject/AppObjectRepo.test.ts +0 -317
  502. package/src/AppObject/AppObjectRepo.ts +0 -203
  503. package/src/AppObject/AppObjectUC.ts +0 -5
  504. package/src/AppObject/AppObjectView.ts +0 -5
  505. package/src/AppObject/getSingletonComponent.test.ts +0 -17
  506. package/src/AppObject/getSingletonComponent.ts +0 -9
  507. package/src/AppObject/index.ts +0 -10
  508. package/src/AppObject/printAppObjectDetails.ts +0 -17
  509. package/src/Entities/MemoizedAngle.test.ts +0 -38
  510. package/src/Entities/MemoizedAngle.ts +0 -25
  511. package/src/Entities/MemoizedBoolean.test.ts +0 -45
  512. package/src/Entities/MemoizedBoolean.ts +0 -23
  513. package/src/Entities/MemoizedColor.test.ts +0 -39
  514. package/src/Entities/MemoizedColor.ts +0 -27
  515. package/src/Entities/MemoizedNumber.test.ts +0 -37
  516. package/src/Entities/MemoizedNumber.ts +0 -23
  517. package/src/Entities/MemoizedQuaternion.test.ts +0 -39
  518. package/src/Entities/MemoizedQuaternion.ts +0 -27
  519. package/src/Entities/MemoizedString.test.ts +0 -37
  520. package/src/Entities/MemoizedString.ts +0 -23
  521. package/src/Entities/MemoizedVector2.test.ts +0 -39
  522. package/src/Entities/MemoizedVector2.ts +0 -27
  523. package/src/Entities/MemoizedVector3.test.ts +0 -39
  524. package/src/Entities/MemoizedVector3.ts +0 -27
  525. package/src/Entities/ObservableEntity.test.ts +0 -28
  526. package/src/Entities/ObservableEntity.ts +0 -17
  527. package/src/Entities/ObserverList.test.ts +0 -61
  528. package/src/Entities/ObserverList.ts +0 -24
  529. package/src/Entities/RangedNumber.test.ts +0 -118
  530. package/src/Entities/RangedNumber.ts +0 -45
  531. package/src/Types/AppBoundary.ts +0 -13
  532. package/src/Types/EaseFn.ts +0 -1
  533. package/src/Types/PmAdapter.ts +0 -15
  534. package/src/Types/SingletonPmAdapter.ts +0 -7
  535. package/src/Utilities/LengthConverters.test.ts +0 -30
  536. package/src/Utilities/LengthConverters.ts +0 -18
  537. package/src/Utilities/LerpNumber.test.ts +0 -109
  538. package/src/Utilities/LerpNumber.ts +0 -109
  539. package/src/Utilities/degreesToRadians.test.ts +0 -8
  540. package/src/Utilities/degreesToRadians.ts +0 -3
  541. package/src/Utilities/easeFunctions.test.ts +0 -251
  542. package/src/Utilities/easeFunctions.ts +0 -180
  543. package/src/Utilities/generateUniqueID.ts +0 -5
  544. package/src/Utilities/interpolateNumber.test.ts +0 -28
  545. package/src/Utilities/interpolateNumber.ts +0 -21
  546. package/src/ValueObjects/Angle.test.ts +0 -30
  547. package/src/ValueObjects/Angle.ts +0 -47
  548. package/src/ValueObjects/Color.test.ts +0 -181
  549. package/src/ValueObjects/Color.ts +0 -891
  550. package/src/ValueObjects/LineSegment2D.test.ts +0 -144
  551. package/src/ValueObjects/LineSegment2D.ts +0 -93
  552. package/src/ValueObjects/Matrix.test.ts +0 -498
  553. package/src/ValueObjects/Matrix.ts +0 -567
  554. package/src/ValueObjects/ParametricLine.test.ts +0 -155
  555. package/src/ValueObjects/ParametricLine.ts +0 -114
  556. package/src/ValueObjects/ParametricPlane.test.ts +0 -122
  557. package/src/ValueObjects/ParametricPlane.ts +0 -82
  558. package/src/ValueObjects/Quaternion.test.ts +0 -356
  559. package/src/ValueObjects/Quaternion.ts +0 -353
  560. package/src/ValueObjects/Rectangle.test.ts +0 -32
  561. package/src/ValueObjects/Rectangle.ts +0 -33
  562. package/src/ValueObjects/Vector2.test.ts +0 -167
  563. package/src/ValueObjects/Vector2.ts +0 -209
  564. package/src/ValueObjects/Vector3.test.ts +0 -228
  565. package/src/ValueObjects/Vector3.ts +0 -269
  566. package/tsconfig.build.json +0 -7
  567. package/tsconfig.cjs.json +0 -9
  568. package/tsconfig.esm.json +0 -12
  569. package/tsconfig.json +0 -19
  570. package/tslint.json +0 -11
@@ -1,317 +0,0 @@
1
- import { AppObject, makeAppObject } from "./AppObject";
2
- import { AppObjectComponent } from "./AppObjectComponent";
3
- import { makeAppObjectRepo } from "./AppObjectRepo";
4
-
5
- function makeTestRig() {
6
- const repo = makeAppObjectRepo();
7
-
8
- const observer = jest.fn();
9
- repo.addObserver(observer);
10
-
11
- return { repo, observer };
12
- }
13
-
14
- describe("Observable appObject Repo", () => {
15
- it("Allows an App Object to be added", () => {
16
- const { repo } = makeTestRig();
17
- const appObject = makeAppObject("appObj", repo);
18
-
19
- expect(repo.has(appObject.id)).toEqual(true);
20
- });
21
-
22
- it("Notifies when an appObject is added", () => {
23
- const { repo, observer } = makeTestRig();
24
- makeAppObject("appObj", repo);
25
-
26
- expect(observer).toBeCalled();
27
- });
28
-
29
- it("Forwards notification from an added App Object", () => {
30
- const { repo, observer } = makeTestRig();
31
- const appObject = makeAppObject("appObj", repo);
32
-
33
- observer.mockClear();
34
-
35
- appObject.notify();
36
-
37
- expect(observer).toBeCalled();
38
- });
39
-
40
- it("Stops notifying if adding an App Object replaces and existing appObject", () => {
41
- const { repo, observer } = makeTestRig();
42
-
43
- const original = makeAppObject("appObj", repo);
44
- makeAppObject("appObj", repo);
45
- observer.mockClear();
46
-
47
- original.notify();
48
-
49
- expect(observer).not.toBeCalled();
50
- });
51
-
52
- it("Removes an App Object", () => {
53
- const { repo } = makeTestRig();
54
- const appObject = makeAppObject("appObj", repo);
55
-
56
- expect(repo.has(appObject.id)).toEqual(true);
57
-
58
- repo.remove(appObject.id);
59
-
60
- expect(repo.has(appObject.id)).toEqual(false);
61
- });
62
-
63
- it("Notifies if an App Object is removed", () => {
64
- const { repo, observer } = makeTestRig();
65
- const appObject = makeAppObject("appObj", repo);
66
- observer.mockClear();
67
-
68
- repo.remove(appObject.id);
69
-
70
- expect(observer).toBeCalled();
71
- });
72
-
73
- it("Does not notify if the App Object to be removed cannot be found", () => {
74
- const { repo, observer } = makeTestRig();
75
-
76
- repo.remove("someId");
77
-
78
- expect(observer).not.toBeCalled();
79
- });
80
-
81
- it("Stops observing a removed App Object", () => {
82
- const { repo, observer } = makeTestRig();
83
- const appObject = makeAppObject("appObj", repo);
84
-
85
- repo.remove(appObject.id);
86
-
87
- observer.mockClear();
88
-
89
- appObject.notify();
90
-
91
- expect(observer).not.toBeCalled();
92
- });
93
-
94
- it("Gets an App Object", () => {
95
- const { repo } = makeTestRig();
96
- const appObject = makeAppObject("appObj", repo);
97
-
98
- expect(repo.get("appObj")).toEqual(appObject);
99
- });
100
-
101
- it("Gets all App Objects", () => {
102
- const { repo } = makeTestRig();
103
- const appObject = makeAppObject("appObj", repo);
104
-
105
- expect(repo.getAll()).toEqual([appObject]);
106
- });
107
-
108
- it("Returns undefined for an unknown App Object", () => {
109
- const { repo } = makeTestRig();
110
-
111
- expect(repo.get("unknownID")).toBeUndefined();
112
- });
113
-
114
- it("Supports notifying an observer when an App Object is added", () => {
115
- const { repo } = makeTestRig();
116
-
117
- const addEntityObserver = jest.fn();
118
- repo.addAppObjectAddedObserver(addEntityObserver);
119
-
120
- const ent = makeAppObject("appObj", repo);
121
-
122
- expect(addEntityObserver).toBeCalledWith(ent);
123
- });
124
-
125
- it("Add App Object observer can be removed", () => {
126
- const { repo } = makeTestRig();
127
-
128
- const addEntityObserver = jest.fn();
129
- repo.addAppObjectAddedObserver(addEntityObserver);
130
- repo.removeAppObjectAddedObserver(addEntityObserver);
131
-
132
- makeAppObject("appObj", repo);
133
-
134
- expect(addEntityObserver).not.toBeCalled();
135
- });
136
-
137
- it("Supports notifying an observer when an App Object is removed", () => {
138
- const { repo } = makeTestRig();
139
-
140
- const removeEntityObserver = jest.fn();
141
- repo.addAppObjectRemovedObserver(removeEntityObserver);
142
-
143
- const ent = makeAppObject("appObj", repo);
144
-
145
- repo.remove("appObj");
146
-
147
- expect(removeEntityObserver).toBeCalledWith(ent);
148
- });
149
-
150
- it("Remove App Object observer can be removed", () => {
151
- const { repo } = makeTestRig();
152
-
153
- const removeEntityObserver = jest.fn();
154
- repo.addAppObjectRemovedObserver(removeEntityObserver);
155
- repo.removedAppObjectRemovedObserver(removeEntityObserver);
156
-
157
- makeAppObject("appObj", repo);
158
- repo.remove("appObj");
159
-
160
- expect(removeEntityObserver).not.toBeCalled();
161
- });
162
-
163
- it("Creats a new App Object when getOrCreate is called but the AO does not exist", () => {
164
- const { repo } = makeTestRig();
165
-
166
- expect(repo.has("ao1")).toEqual(false);
167
-
168
- const ao = repo.getOrCreate("ao1");
169
-
170
- expect(ao.id).toEqual("ao1");
171
- expect(repo.has("ao1")).toEqual(true);
172
- });
173
-
174
- it("Gets the existing App Object when getOrCreate is called and the AO exists", () => {
175
- const { repo } = makeTestRig();
176
-
177
- const appObject = makeAppObject("appObj", repo);
178
- const ao = repo.getOrCreate("appObj");
179
-
180
- expect(ao).toEqual(appObject);
181
- });
182
-
183
- it("Get all App Objects with component type", () => {
184
- const { repo } = makeTestRig();
185
-
186
- expect(repo.getAllAppObjectsWithComponent(MockComponent.type)).toEqual([]);
187
-
188
- makeAppObject("appObj1", repo);
189
- const appObj2 = makeAppObject("appObj2", repo);
190
- const appObj3 = makeAppObject("appObj3", repo);
191
-
192
- new MockComponent(appObj2);
193
- new MockComponent(appObj3);
194
-
195
- expect(repo.getAllAppObjectsWithComponent(MockComponent.type)).toEqual([
196
- appObj2,
197
- appObj3,
198
- ]);
199
- });
200
-
201
- it("Get a component on an object", () => {
202
- const { repo } = makeTestRig();
203
-
204
- const appObj = repo.getOrCreate("appObj");
205
-
206
- const comp = new MockComponent(appObj);
207
-
208
- expect(repo.getAppObjectComponent("appObj", MockComponent.type)).toEqual(
209
- comp
210
- );
211
- });
212
-
213
- it("Returns undefined if the App Object does not have an entity when calling get entity on object", () => {
214
- const { repo } = makeTestRig();
215
-
216
- repo.getOrCreate("appObj");
217
-
218
- expect(repo.getAppObjectComponent("appObj", MockComponent.type)).toEqual(
219
- undefined
220
- );
221
- });
222
-
223
- it("Returns undefined if the App Object does not exist when calling get entity on object", () => {
224
- const { repo } = makeTestRig();
225
- expect(repo.getAppObjectComponent("appObj", MockComponent.type)).toEqual(
226
- undefined
227
- );
228
- });
229
-
230
- it("Get all Components", () => {
231
- const { repo } = makeTestRig();
232
-
233
- expect(repo.getAllComponents<MockComponent>(MockComponent.type)).toEqual(
234
- []
235
- );
236
-
237
- const appObj1 = makeAppObject("appObj2", repo);
238
- const comp1 = new MockComponent(appObj1);
239
-
240
- const appObj2 = makeAppObject("appObj3", repo);
241
- const comp2 = new MockComponent(appObj2);
242
-
243
- expect(repo.getAllComponents<MockComponent>(MockComponent.type)).toEqual([
244
- comp1,
245
- comp2,
246
- ]);
247
- });
248
-
249
- it("Registers a singleton", () => {
250
- const { repo } = makeTestRig();
251
- const appObj1 = makeAppObject("appObj2", repo);
252
- const comp1 = new MockComponent(appObj1);
253
-
254
- repo.registerSingleton(comp1);
255
-
256
- expect(repo.getSingleton(MockComponent.type)).toEqual(comp1);
257
- });
258
-
259
- it("Warns and replaces if multiple singleton are registered", () => {
260
- const { repo } = makeTestRig();
261
- const appObj1 = makeAppObject("appObj1", repo);
262
- const comp1 = new MockComponent(appObj1);
263
-
264
- repo.registerSingleton(comp1);
265
-
266
- const appObj2 = makeAppObject("appObj2", repo);
267
- const comp2 = new MockComponent(appObj2);
268
-
269
- repo.submitWarning = jest.fn();
270
-
271
- repo.registerSingleton(comp2);
272
- expect(repo.getSingleton(MockComponent.type)).toEqual(comp2);
273
- expect(repo.submitWarning).toBeCalled();
274
- });
275
-
276
- it("Searches for a singleton that has not been registered", () => {
277
- const { repo } = makeTestRig();
278
- const appObj1 = makeAppObject("appObj2", repo);
279
- const comp1 = new MockComponent(appObj1);
280
-
281
- repo.registerSingleton(comp1);
282
-
283
- expect(repo.getSingleton(MockComponent.type)).toEqual(comp1);
284
- });
285
-
286
- it("Warns if it cannot find a singleton", () => {
287
- const { repo } = makeTestRig();
288
-
289
- repo.submitWarning = jest.fn();
290
-
291
- repo.getSingleton(MockComponent.type);
292
-
293
- expect(repo.submitWarning).toBeCalled();
294
- });
295
-
296
-
297
- it("Warns if it finds multiple singletons and returns the first one", () => {
298
- const { repo } = makeTestRig();
299
- const appObj1 = makeAppObject("appObj1", repo);
300
- const comp1 = new MockComponent(appObj1);
301
-
302
- const appObj2 = makeAppObject("appObj2", repo);
303
- new MockComponent(appObj2);
304
-
305
- repo.submitWarning = jest.fn();
306
-
307
- expect(repo.getSingleton(MockComponent.type)).toEqual(comp1);
308
- expect(repo.submitWarning).toBeCalled();
309
- });
310
- });
311
-
312
- class MockComponent extends AppObjectComponent {
313
- static readonly type: string = "mockComponent";
314
- constructor(appObject: AppObject) {
315
- super(appObject, MockComponent.type);
316
- }
317
- }
@@ -1,203 +0,0 @@
1
- import { ObservableEntity, ObserverList } from "../Entities";
2
- import { AppObject, makeAppObject } from "./AppObject";
3
- import { AppObjectComponent } from "./AppObjectComponent";
4
-
5
- export abstract class AppObjectRepo extends ObservableEntity {
6
- abstract has(appObjectID: string): boolean;
7
- abstract add(appObject: AppObject): void;
8
- abstract remove(appObjectID: string): void;
9
- abstract get(appObjectID: string): AppObject | undefined;
10
- abstract getOrCreate(appObjectID: string): AppObject;
11
- abstract getAll(): AppObject[];
12
-
13
- abstract submitLog(sender: string, message: string): void;
14
- abstract submitWarning(sender: string, message: string): void;
15
- abstract submitError(sender: string, message: string): void;
16
- abstract submitFatal(sender: string, message: string): void;
17
-
18
- abstract registerSingleton(component: AppObjectComponent): void;
19
- abstract getSingleton<T extends AppObjectComponent>(
20
- type: string
21
- ): T | undefined;
22
-
23
- abstract getAppObjectComponent<T extends AppObjectComponent>(
24
- appObjectID: string,
25
- type: string
26
- ): T | undefined;
27
- abstract getAllAppObjectsWithComponent(componentType: string): AppObject[];
28
- abstract getAllComponents<T extends AppObjectComponent>(type: string): T[];
29
-
30
- abstract addAppObjectAddedObserver: (
31
- observer: (addedEntity: AppObject) => void
32
- ) => void;
33
- abstract removeAppObjectAddedObserver: (
34
- observer: (addedEntity: AppObject) => void
35
- ) => void;
36
-
37
- abstract addAppObjectRemovedObserver: (
38
- observer: (addedEntity: AppObject) => void
39
- ) => void;
40
- abstract removedAppObjectRemovedObserver: (
41
- observer: (addedEntity: AppObject) => void
42
- ) => void;
43
- }
44
-
45
- export function makeAppObjectRepo(): AppObjectRepo {
46
- return new AppObjectRepoImp();
47
- }
48
-
49
- class AppObjectRepoImp extends AppObjectRepo {
50
- private appObjectLookup = new Map<string, AppObject>();
51
- private singletons = new Map<string, AppObjectComponent>();
52
-
53
- private onAppObjectAddedObserver = new ObserverList<AppObject>();
54
- addAppObjectAddedObserver = (observer: (addedEntity: AppObject) => void) => {
55
- this.onAppObjectAddedObserver.add(observer);
56
- };
57
- removeAppObjectAddedObserver = (
58
- observer: (addedEntity: AppObject) => void
59
- ): void => {
60
- this.onAppObjectAddedObserver.remove(observer);
61
- };
62
-
63
- private onAppObjectRemovedObservers = new ObserverList<AppObject>();
64
- addAppObjectRemovedObserver = (
65
- observer: (removedEntity: AppObject) => void
66
- ) => {
67
- this.onAppObjectRemovedObservers.add(observer);
68
- };
69
- removedAppObjectRemovedObserver = (
70
- observer: (removedEntity: AppObject) => void
71
- ): void => {
72
- this.onAppObjectRemovedObservers.remove(observer);
73
- };
74
-
75
- has = (id: string): boolean => {
76
- return this.appObjectLookup.has(id);
77
- };
78
-
79
- add = (appObject: AppObject) => {
80
- const existing = this.appObjectLookup.get(appObject.id);
81
- if (existing) {
82
- existing.removeObserver(this.notify);
83
- }
84
-
85
- this.appObjectLookup.set(appObject.id, appObject);
86
- appObject.addObserver(this.notify);
87
- this.notify();
88
- this.onAppObjectAddedObserver.notify(appObject);
89
- };
90
-
91
- remove = (id: string) => {
92
- const existing = this.appObjectLookup.get(id);
93
- if (!existing) return;
94
-
95
- this.appObjectLookup.delete(id);
96
- existing.removeObserver(this.notify);
97
- this.notify();
98
- this.onAppObjectRemovedObservers.notify(existing);
99
- };
100
-
101
- get = (id: string): AppObject | undefined => {
102
- return this.appObjectLookup.get(id);
103
- };
104
-
105
- getOrCreate = (id: string): AppObject => {
106
- const existing = this.appObjectLookup.get(id);
107
-
108
- if (!existing) {
109
- return makeAppObject(id, this);
110
- } else {
111
- return existing;
112
- }
113
- };
114
-
115
- getAll = (): AppObject[] => {
116
- return Array.from(this.appObjectLookup.values());
117
- };
118
-
119
- getAllAppObjectsWithComponent(componentType: string): AppObject[] {
120
- const rArray: AppObject[] = [];
121
-
122
- this.appObjectLookup.forEach((appObj) => {
123
- if (appObj.hasComponent(componentType)) {
124
- rArray.push(appObj);
125
- }
126
- });
127
-
128
- return rArray;
129
- }
130
-
131
- getAllComponents<T extends AppObjectComponent>(type: string): T[] {
132
- const rArray: T[] = [];
133
-
134
- this.appObjectLookup.forEach((appObj) => {
135
- const aoEntity = appObj.getComponent(type);
136
- if (aoEntity) {
137
- rArray.push(aoEntity as T);
138
- }
139
- });
140
-
141
- return rArray;
142
- }
143
-
144
- getAppObjectComponent<T extends AppObjectComponent>(
145
- id: string,
146
- entityType: string
147
- ): T | undefined {
148
- const ao = this.appObjectLookup.get(id);
149
- if (!ao) {
150
- return undefined;
151
- }
152
-
153
- return ao.getComponent(entityType) as T;
154
- }
155
-
156
- submitLog(sender: string, message: string): void {
157
- console.log(`[${sender}]: ${message}`);
158
- }
159
- submitWarning(sender: string, message: string): void {
160
- console.warn(`[${sender}]: ${message}`);
161
- }
162
- submitError(sender: string, message: string): void {
163
- console.error(`[${sender}]: ${message}`);
164
- }
165
- submitFatal(sender: string, message: string): void {
166
- console.error(`FATAL ERROR - [${sender}]: ${message}`);
167
- }
168
-
169
- registerSingleton(component: AppObjectComponent): void {
170
- if (this.singletons.has(component.type)) {
171
- this.submitWarning(
172
- "AppObjectRepo",
173
- `Singleton for type ${component.type} already exists. Relpacing`
174
- );
175
- }
176
-
177
- this.singletons.set(component.type, component);
178
- }
179
-
180
- getSingleton<T extends AppObjectComponent>(type: string): T | undefined {
181
- if (this.singletons.has(type)) {
182
- return this.singletons.get(type) as T;
183
- }
184
-
185
- const components = this.getAllComponents<AppObjectComponent>(type);
186
- if (components.length === 1) {
187
- this.singletons.set(components[0].type, components[0]);
188
- return components[0] as T;
189
- } else if (components.length === 0) {
190
- this.submitWarning(
191
- "AppObjectRepo",
192
- `Unable to find a singleton for ${type}`
193
- );
194
- return undefined;
195
- } else if (components.length > 1) {
196
- this.submitWarning(
197
- "AppObjectRepo",
198
- `Multiple ${type} found. There should only be one if it truly a singleton. Using the first one`
199
- );
200
- return components[0] as T;
201
- }
202
- }
203
- }
@@ -1,5 +0,0 @@
1
- import { AppObjectComponent, AppObjectComponentType } from "./AppObjectComponent";
2
-
3
- export class AppObjectUC extends AppObjectComponent {
4
- readonly componentType = AppObjectComponentType.UC;
5
- }
@@ -1,5 +0,0 @@
1
- import { AppObjectComponent, AppObjectComponentType } from "./AppObjectComponent";
2
-
3
- export class AppObjectView extends AppObjectComponent {
4
- readonly componentType = AppObjectComponentType.VIEW;
5
- }
@@ -1,17 +0,0 @@
1
- import { makeAppObjectRepo } from "./AppObjectRepo";
2
- import { getSingletonComponent } from "./getSingletonComponent";
3
-
4
- describe("Get Singleton Component", () => {
5
- it("Calls the get singleton on the app object repo", () => {
6
- const appObjects = makeAppObjectRepo();
7
-
8
- appObjects.getSingleton = jest.fn();
9
-
10
- getSingletonComponent(
11
- "Mock Component",
12
- appObjects
13
- );
14
-
15
- expect(appObjects.getSingleton).toBeCalledWith("Mock Component")
16
- });
17
- });
@@ -1,9 +0,0 @@
1
- import { AppObjectComponent } from "./AppObjectComponent";
2
- import { AppObjectRepo } from "./AppObjectRepo";
3
-
4
- export function getSingletonComponent<T extends AppObjectComponent>(
5
- type: string,
6
- appObjects: AppObjectRepo
7
- ): T | undefined {
8
- return appObjects.getSingleton<T>(type);
9
- }
@@ -1,10 +0,0 @@
1
- export * from "./AppObject"
2
- export * from "./AppObjectEntity"
3
- export * from "./AppObjectEntityRepo"
4
- export * from "./AppObjectPM"
5
- export * from "./AppObjectRepo"
6
- export * from "./AppObjectUC"
7
- export * from "./AppObjectController"
8
- export * from "./AppObjectView"
9
- export * from "./getSingletonComponent";
10
- export * from "./printAppObjectDetails";
@@ -1,17 +0,0 @@
1
- import { AppObjectRepo } from "./AppObjectRepo";
2
-
3
- export function printAppObjectDetails(id: string, appObjects: AppObjectRepo) {
4
- const appObject = appObjects.get(id);
5
- if (!appObject) {
6
- console.warn("[printAppObjectDetails] Unable to find App Object by ID");
7
- return;
8
- }
9
-
10
- console.log("[printAppObjectDetails] Start App Object Details ---");
11
- console.log(`id: ${appObject.id}`);
12
- const components = appObject.allComponents();
13
- components.forEach((component) => {
14
- console.log(`Has Component: ${component.type}`);
15
- });
16
- console.log("[printAppObjectDetails] End App Object Details ---");
17
- }
@@ -1,38 +0,0 @@
1
- import { Angle } from "../ValueObjects";
2
- import { MemoizedAngle } from "./MemoizedAngle";
3
-
4
- test("Initial value is stored", () => {
5
- const memoizedNumber = new MemoizedAngle(Angle.FromDegrees(55), jest.fn());
6
- expect(memoizedNumber.val.degrees).toEqual(55);
7
- });
8
-
9
- test("Callback is called when something changes", () => {
10
- const cb = jest.fn();
11
- const memoizedNumber = new MemoizedAngle(Angle.FromDegrees(33), cb);
12
-
13
- expect(cb).not.toBeCalled();
14
-
15
- memoizedNumber.val = Angle.FromDegrees(55);
16
-
17
- expect(cb).toBeCalled();
18
- });
19
-
20
- test("CB is only called when something has changed", () => {
21
- const cb = jest.fn();
22
- const memoizedNumber = new MemoizedAngle(Angle.FromDegrees(33), cb);
23
-
24
- memoizedNumber.val = Angle.FromDegrees(33);
25
- memoizedNumber.val = Angle.FromDegrees(33);
26
- memoizedNumber.val = Angle.FromDegrees(33);
27
-
28
- expect(cb).not.toBeCalled();
29
- });
30
-
31
- test("Setting the value quietly should not notify", () => {
32
- const cb = jest.fn();
33
- const memoizedBoolean = new MemoizedAngle(Angle.FromDegrees(33), cb);
34
-
35
- memoizedBoolean.setValQuietly(Angle.FromDegrees(55));
36
-
37
- expect(cb).not.toBeCalled();
38
- });
@@ -1,25 +0,0 @@
1
- import { Angle } from "../ValueObjects";
2
-
3
- export class MemoizedAngle {
4
- private _val: Angle;
5
- get val(): Angle {
6
- return this._val;
7
- }
8
- set val(b: Angle) {
9
- if (this._val.degrees === b.degrees) return;
10
-
11
- this._val = b;
12
- this.onChangeCallback();
13
- }
14
-
15
- public setValQuietly(val: Angle) {
16
- this._val = val;
17
- }
18
-
19
- private onChangeCallback: () => void;
20
-
21
- constructor(initialValue: Angle, onChangeCallback: () => void) {
22
- this._val = initialValue;
23
- this.onChangeCallback = onChangeCallback;
24
- }
25
- }
@@ -1,45 +0,0 @@
1
- import { MemoizedBoolean } from "./MemoizedBoolean";
2
-
3
- test("Initial value is stored", ()=>{
4
- const memoizedTrue = new MemoizedBoolean(true, jest.fn());
5
- expect(memoizedTrue.val).toEqual(true);
6
-
7
- const memoizedFalse = new MemoizedBoolean(false, jest.fn());
8
- expect(memoizedFalse.val).toEqual(false);
9
- })
10
-
11
- test("Callback is called when something changes", ()=>{
12
- const cb = jest.fn();
13
- const memoizedBoolean = new MemoizedBoolean(true, cb);
14
-
15
- expect(cb).not.toBeCalled();
16
-
17
- memoizedBoolean.val = false;
18
-
19
- expect(cb).toBeCalled();
20
- cb.mockClear();
21
-
22
- memoizedBoolean.val = true;
23
-
24
- expect(cb).toBeCalled();
25
- })
26
-
27
- test("CB is only called when something has changed", ()=>{
28
- const cb = jest.fn();
29
- const memoizedBoolean = new MemoizedBoolean(true, cb);
30
-
31
- memoizedBoolean.val = true;
32
- memoizedBoolean.val = true;
33
- memoizedBoolean.val = true;
34
-
35
- expect(cb).not.toBeCalled();
36
- })
37
-
38
- test("Setting the value quietly should not notify", ()=>{
39
- const cb = jest.fn();
40
- const memoizedBoolean = new MemoizedBoolean(true, cb);
41
-
42
- memoizedBoolean.setValQuietly(false);
43
-
44
- expect(cb).not.toBeCalled();
45
- })