@drincs/pixi-vn 0.6.0 → 0.6.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 (415) hide show
  1. package/dist/{TickerBase-RQDWNI4K.d.ts → TickerBase-3rLpDpmb.d.ts} +27 -13
  2. package/dist/{TickerBase-B5CQCJs8.d.mts → TickerBase-DKYzbzro.d.mts} +27 -13
  3. package/dist/classes/CanvasEvent.d.mts +7 -1
  4. package/dist/classes/CanvasEvent.d.ts +7 -1
  5. package/dist/classes/CanvasEvent.js +7 -0
  6. package/dist/classes/CanvasEvent.js.map +1 -1
  7. package/dist/classes/CanvasEvent.mjs +7 -0
  8. package/dist/classes/CanvasEvent.mjs.map +1 -1
  9. package/dist/classes/CharacterBaseModel.d.mts +2 -26
  10. package/dist/classes/CharacterBaseModel.d.ts +2 -26
  11. package/dist/classes/CharacterBaseModel.js +544 -241
  12. package/dist/classes/CharacterBaseModel.js.map +1 -1
  13. package/dist/classes/CharacterBaseModel.mjs +540 -241
  14. package/dist/classes/CharacterBaseModel.mjs.map +1 -1
  15. package/dist/classes/ChoiceMenuOption.d.mts +27 -17
  16. package/dist/classes/ChoiceMenuOption.d.ts +27 -17
  17. package/dist/classes/ChoiceMenuOption.js +548 -243
  18. package/dist/classes/ChoiceMenuOption.js.map +1 -1
  19. package/dist/classes/ChoiceMenuOption.mjs +544 -243
  20. package/dist/classes/ChoiceMenuOption.mjs.map +1 -1
  21. package/dist/classes/CloseLabel.d.mts +1 -1
  22. package/dist/classes/CloseLabel.d.ts +1 -1
  23. package/dist/classes/CloseLabel.js +1 -1
  24. package/dist/classes/CloseLabel.js.map +1 -1
  25. package/dist/classes/CloseLabel.mjs +1 -1
  26. package/dist/classes/CloseLabel.mjs.map +1 -1
  27. package/dist/classes/DialogueBaseModel.d.mts +3 -2
  28. package/dist/classes/DialogueBaseModel.d.ts +3 -2
  29. package/dist/classes/DialogueBaseModel.js +5 -5
  30. package/dist/classes/DialogueBaseModel.js.map +1 -1
  31. package/dist/classes/DialogueBaseModel.mjs +5 -5
  32. package/dist/classes/DialogueBaseModel.mjs.map +1 -1
  33. package/dist/classes/Label.d.mts +1 -1
  34. package/dist/classes/Label.d.ts +1 -1
  35. package/dist/classes/Label.js +1 -1
  36. package/dist/classes/Label.js.map +1 -1
  37. package/dist/classes/Label.mjs +1 -1
  38. package/dist/classes/Label.mjs.map +1 -1
  39. package/dist/classes/StoredClassModel.d.mts +2 -2
  40. package/dist/classes/StoredClassModel.d.ts +2 -2
  41. package/dist/classes/StoredClassModel.js +544 -241
  42. package/dist/classes/StoredClassModel.js.map +1 -1
  43. package/dist/classes/StoredClassModel.mjs +540 -241
  44. package/dist/classes/StoredClassModel.mjs.map +1 -1
  45. package/dist/classes/canvas/CanvasBase.d.mts +5 -1
  46. package/dist/classes/canvas/CanvasBase.d.ts +5 -1
  47. package/dist/classes/canvas/CanvasBase.js +7 -0
  48. package/dist/classes/canvas/CanvasBase.js.map +1 -1
  49. package/dist/classes/canvas/CanvasBase.mjs +7 -0
  50. package/dist/classes/canvas/CanvasBase.mjs.map +1 -1
  51. package/dist/classes/canvas/CanvasContainer.d.mts +4 -1
  52. package/dist/classes/canvas/CanvasContainer.d.ts +4 -1
  53. package/dist/classes/canvas/CanvasContainer.js +57 -37
  54. package/dist/classes/canvas/CanvasContainer.js.map +1 -1
  55. package/dist/classes/canvas/CanvasContainer.mjs +57 -38
  56. package/dist/classes/canvas/CanvasContainer.mjs.map +1 -1
  57. package/dist/classes/canvas/CanvasImage.d.mts +4 -2
  58. package/dist/classes/canvas/CanvasImage.d.ts +4 -2
  59. package/dist/classes/canvas/CanvasImage.js +33 -20
  60. package/dist/classes/canvas/CanvasImage.js.map +1 -1
  61. package/dist/classes/canvas/CanvasImage.mjs +30 -20
  62. package/dist/classes/canvas/CanvasImage.mjs.map +1 -1
  63. package/dist/classes/canvas/CanvasSprite.d.mts +6 -3
  64. package/dist/classes/canvas/CanvasSprite.d.ts +6 -3
  65. package/dist/classes/canvas/CanvasSprite.js +25 -17
  66. package/dist/classes/canvas/CanvasSprite.js.map +1 -1
  67. package/dist/classes/canvas/CanvasSprite.mjs +25 -18
  68. package/dist/classes/canvas/CanvasSprite.mjs.map +1 -1
  69. package/dist/classes/canvas/CanvasText.d.mts +6 -3
  70. package/dist/classes/canvas/CanvasText.d.ts +6 -3
  71. package/dist/classes/canvas/CanvasText.js +25 -17
  72. package/dist/classes/canvas/CanvasText.js.map +1 -1
  73. package/dist/classes/canvas/CanvasText.mjs +25 -18
  74. package/dist/classes/canvas/CanvasText.mjs.map +1 -1
  75. package/dist/classes/canvas/index.js +184 -158
  76. package/dist/classes/canvas/index.js.map +1 -1
  77. package/dist/classes/canvas/index.mjs +184 -158
  78. package/dist/classes/canvas/index.mjs.map +1 -1
  79. package/dist/classes/index.d.mts +6 -4
  80. package/dist/classes/index.d.ts +6 -4
  81. package/dist/classes/index.js +560 -248
  82. package/dist/classes/index.js.map +1 -1
  83. package/dist/classes/index.mjs +556 -248
  84. package/dist/classes/index.mjs.map +1 -1
  85. package/dist/classes/ticker/FadeAlphaTicker.d.mts +27 -0
  86. package/dist/classes/ticker/FadeAlphaTicker.d.ts +27 -0
  87. package/dist/classes/ticker/{TickerFadeAlpha.js → FadeAlphaTicker.js} +549 -248
  88. package/dist/classes/ticker/FadeAlphaTicker.js.map +1 -0
  89. package/dist/classes/ticker/{TickerRotate.mjs → FadeAlphaTicker.mjs} +571 -274
  90. package/dist/classes/ticker/FadeAlphaTicker.mjs.map +1 -0
  91. package/dist/classes/ticker/MoveTicker.d.mts +25 -0
  92. package/dist/classes/ticker/MoveTicker.d.ts +25 -0
  93. package/dist/classes/ticker/{TickerMove.js → MoveTicker.js} +544 -241
  94. package/dist/classes/ticker/MoveTicker.js.map +1 -0
  95. package/dist/classes/ticker/{TickerFadeAlpha.mjs → MoveTicker.mjs} +568 -269
  96. package/dist/classes/ticker/MoveTicker.mjs.map +1 -0
  97. package/dist/classes/ticker/RotateTicker.d.mts +27 -0
  98. package/dist/classes/ticker/RotateTicker.d.ts +27 -0
  99. package/dist/classes/ticker/{TickerRotate.js → RotateTicker.js} +544 -241
  100. package/dist/classes/ticker/RotateTicker.js.map +1 -0
  101. package/dist/classes/ticker/{TickerMove.mjs → RotateTicker.mjs} +558 -259
  102. package/dist/classes/ticker/RotateTicker.mjs.map +1 -0
  103. package/dist/classes/ticker/TickerBase.d.mts +2 -1
  104. package/dist/classes/ticker/TickerBase.d.ts +2 -1
  105. package/dist/classes/ticker/TickerBase.js +12 -6
  106. package/dist/classes/ticker/TickerBase.js.map +1 -1
  107. package/dist/classes/ticker/TickerBase.mjs +12 -6
  108. package/dist/classes/ticker/TickerBase.mjs.map +1 -1
  109. package/dist/classes/ticker/ZoomTicker.d.mts +31 -0
  110. package/dist/classes/ticker/ZoomTicker.d.ts +31 -0
  111. package/dist/classes/ticker/ZoomTicker.js +1647 -0
  112. package/dist/classes/ticker/ZoomTicker.js.map +1 -0
  113. package/dist/classes/ticker/ZoomTicker.mjs +1639 -0
  114. package/dist/classes/ticker/ZoomTicker.mjs.map +1 -0
  115. package/dist/classes/ticker/index.d.mts +11 -8
  116. package/dist/classes/ticker/index.d.ts +11 -8
  117. package/dist/classes/ticker/index.js +567 -266
  118. package/dist/classes/ticker/index.js.map +1 -1
  119. package/dist/classes/ticker/index.mjs +564 -267
  120. package/dist/classes/ticker/index.mjs.map +1 -1
  121. package/dist/constants.d.mts +12 -2
  122. package/dist/constants.d.ts +12 -2
  123. package/dist/constants.js +10 -1
  124. package/dist/constants.js.map +1 -1
  125. package/dist/constants.mjs +9 -2
  126. package/dist/constants.mjs.map +1 -1
  127. package/dist/decorators/CanvasElementDecorator.d.mts +3 -3
  128. package/dist/decorators/CanvasElementDecorator.d.ts +3 -3
  129. package/dist/decorators/CanvasElementDecorator.js +63 -43
  130. package/dist/decorators/CanvasElementDecorator.js.map +1 -1
  131. package/dist/decorators/CanvasElementDecorator.mjs +62 -42
  132. package/dist/decorators/CanvasElementDecorator.mjs.map +1 -1
  133. package/dist/decorators/CharacterDecorator.d.mts +1 -0
  134. package/dist/decorators/CharacterDecorator.d.ts +1 -0
  135. package/dist/decorators/CharacterDecorator.js +1 -1
  136. package/dist/decorators/CharacterDecorator.js.map +1 -1
  137. package/dist/decorators/CharacterDecorator.mjs +1 -1
  138. package/dist/decorators/CharacterDecorator.mjs.map +1 -1
  139. package/dist/decorators/EventDecorator.d.mts +7 -7
  140. package/dist/decorators/EventDecorator.d.ts +7 -7
  141. package/dist/decorators/EventDecorator.js +12 -11
  142. package/dist/decorators/EventDecorator.js.map +1 -1
  143. package/dist/decorators/EventDecorator.mjs +11 -10
  144. package/dist/decorators/EventDecorator.mjs.map +1 -1
  145. package/dist/decorators/LabelDecorator.d.mts +4 -3
  146. package/dist/decorators/LabelDecorator.d.ts +4 -3
  147. package/dist/decorators/LabelDecorator.js +546 -243
  148. package/dist/decorators/LabelDecorator.js.map +1 -1
  149. package/dist/decorators/LabelDecorator.mjs +542 -243
  150. package/dist/decorators/LabelDecorator.mjs.map +1 -1
  151. package/dist/decorators/TickerDecorator.d.mts +9 -6
  152. package/dist/decorators/TickerDecorator.d.ts +9 -6
  153. package/dist/decorators/TickerDecorator.js +7 -6
  154. package/dist/decorators/TickerDecorator.js.map +1 -1
  155. package/dist/decorators/TickerDecorator.mjs +7 -6
  156. package/dist/decorators/TickerDecorator.mjs.map +1 -1
  157. package/dist/decorators/index.d.mts +4 -3
  158. package/dist/decorators/index.d.ts +4 -3
  159. package/dist/decorators/index.js +550 -245
  160. package/dist/decorators/index.js.map +1 -1
  161. package/dist/decorators/index.mjs +546 -245
  162. package/dist/decorators/index.mjs.map +1 -1
  163. package/dist/functions/CanvasUtility.js +56 -37
  164. package/dist/functions/CanvasUtility.js.map +1 -1
  165. package/dist/functions/CanvasUtility.mjs +56 -37
  166. package/dist/functions/CanvasUtility.mjs.map +1 -1
  167. package/dist/functions/DialogueUtility.d.mts +7 -5
  168. package/dist/functions/DialogueUtility.d.ts +7 -5
  169. package/dist/functions/DialogueUtility.js +729 -397
  170. package/dist/functions/DialogueUtility.js.map +1 -1
  171. package/dist/functions/DialogueUtility.mjs +729 -397
  172. package/dist/functions/DialogueUtility.mjs.map +1 -1
  173. package/dist/functions/FlagsUtility.js +544 -241
  174. package/dist/functions/FlagsUtility.js.map +1 -1
  175. package/dist/functions/FlagsUtility.mjs +540 -241
  176. package/dist/functions/FlagsUtility.mjs.map +1 -1
  177. package/dist/functions/GameUtility.js +544 -241
  178. package/dist/functions/GameUtility.js.map +1 -1
  179. package/dist/functions/GameUtility.mjs +540 -241
  180. package/dist/functions/GameUtility.mjs.map +1 -1
  181. package/dist/functions/ImageUtility.d.mts +81 -8
  182. package/dist/functions/ImageUtility.d.ts +81 -8
  183. package/dist/functions/ImageUtility.js +911 -387
  184. package/dist/functions/ImageUtility.js.map +1 -1
  185. package/dist/functions/ImageUtility.mjs +899 -387
  186. package/dist/functions/ImageUtility.mjs.map +1 -1
  187. package/dist/functions/SavesUtility.d.mts +9 -5
  188. package/dist/functions/SavesUtility.d.ts +9 -5
  189. package/dist/functions/SavesUtility.js +611 -252
  190. package/dist/functions/SavesUtility.js.map +1 -1
  191. package/dist/functions/SavesUtility.mjs +611 -252
  192. package/dist/functions/SavesUtility.mjs.map +1 -1
  193. package/dist/functions/TickerUtility.d.mts +1 -1
  194. package/dist/functions/TickerUtility.d.ts +1 -1
  195. package/dist/functions/TickerUtility.js +32 -18
  196. package/dist/functions/TickerUtility.js.map +1 -1
  197. package/dist/functions/TickerUtility.mjs +32 -18
  198. package/dist/functions/TickerUtility.mjs.map +1 -1
  199. package/dist/functions/index.d.mts +18 -8
  200. package/dist/functions/index.d.ts +18 -8
  201. package/dist/functions/index.js +832 -279
  202. package/dist/functions/index.js.map +1 -1
  203. package/dist/functions/index.mjs +825 -280
  204. package/dist/functions/index.mjs.map +1 -1
  205. package/dist/index.d.mts +25 -16
  206. package/dist/index.d.ts +25 -16
  207. package/dist/index.js +1547 -290
  208. package/dist/index.js.map +1 -1
  209. package/dist/index.mjs +1538 -290
  210. package/dist/index.mjs.map +1 -1
  211. package/dist/interface/CharacterBaseModelProps.d.mts +27 -0
  212. package/dist/interface/CharacterBaseModelProps.d.ts +27 -0
  213. package/dist/interface/CharacterBaseModelProps.js +4 -0
  214. package/dist/interface/CharacterBaseModelProps.mjs +3 -0
  215. package/dist/interface/DialogueHistory.d.mts +3 -7
  216. package/dist/interface/DialogueHistory.d.ts +3 -7
  217. package/dist/interface/IHistoryStep.d.mts +12 -8
  218. package/dist/interface/IHistoryStep.d.ts +12 -8
  219. package/dist/interface/ISaveData.d.mts +8 -4
  220. package/dist/interface/ISaveData.d.ts +8 -4
  221. package/dist/interface/ITicker.d.mts +2 -1
  222. package/dist/interface/ITicker.d.ts +2 -1
  223. package/dist/interface/ITickersSteps.d.mts +14 -5
  224. package/dist/interface/ITickersSteps.d.ts +14 -5
  225. package/dist/interface/TickerHistory.d.mts +29 -0
  226. package/dist/interface/TickerHistory.d.ts +29 -0
  227. package/dist/{types/ticker/TickerMoveProps.js → interface/TickerHistory.js} +1 -1
  228. package/dist/interface/TickerHistory.mjs +3 -0
  229. package/dist/interface/TickerProgrationType.d.mts +13 -1
  230. package/dist/interface/TickerProgrationType.d.ts +13 -1
  231. package/dist/interface/TickerTimeoutHistory.d.mts +7 -0
  232. package/dist/interface/TickerTimeoutHistory.d.ts +7 -0
  233. package/dist/interface/TickerTimeoutHistory.js +4 -0
  234. package/dist/interface/TickerTimeoutHistory.mjs +3 -0
  235. package/dist/interface/canvas/ICanvasBaseMemory.d.mts +1 -1
  236. package/dist/interface/canvas/ICanvasBaseMemory.d.ts +1 -1
  237. package/dist/interface/canvas/ICanvasImageMemory.d.mts +1 -1
  238. package/dist/interface/canvas/ICanvasImageMemory.d.ts +1 -1
  239. package/dist/interface/canvas/ICanvasSpriteMemory.d.mts +0 -1
  240. package/dist/interface/canvas/ICanvasSpriteMemory.d.ts +0 -1
  241. package/dist/interface/canvas/ICanvasTextTextMemory.d.mts +0 -1
  242. package/dist/interface/canvas/ICanvasTextTextMemory.d.ts +0 -1
  243. package/dist/interface/export/ExportedCanvas.d.mts +11 -3
  244. package/dist/interface/export/ExportedCanvas.d.ts +11 -3
  245. package/dist/interface/export/ExportedStep.d.mts +7 -3
  246. package/dist/interface/export/ExportedStep.d.ts +7 -3
  247. package/dist/interface/export/index.d.mts +8 -4
  248. package/dist/interface/export/index.d.ts +8 -4
  249. package/dist/interface/index.d.mts +14 -11
  250. package/dist/interface/index.d.ts +14 -11
  251. package/dist/labels/BaseCanvasElementTestLabel.d.mts +9 -0
  252. package/dist/labels/BaseCanvasElementTestLabel.d.ts +9 -0
  253. package/dist/labels/BaseCanvasElementTestLabel.js +1888 -0
  254. package/dist/labels/BaseCanvasElementTestLabel.js.map +1 -0
  255. package/dist/labels/BaseCanvasElementTestLabel.mjs +1882 -0
  256. package/dist/labels/BaseCanvasElementTestLabel.mjs.map +1 -0
  257. package/dist/labels/CanvasEventsTestLabel.d.mts +27 -0
  258. package/dist/labels/CanvasEventsTestLabel.d.ts +27 -0
  259. package/dist/labels/CanvasEventsTestLabel.js +2822 -0
  260. package/dist/labels/CanvasEventsTestLabel.js.map +1 -0
  261. package/dist/labels/CanvasEventsTestLabel.mjs +2816 -0
  262. package/dist/labels/CanvasEventsTestLabel.mjs.map +1 -0
  263. package/dist/labels/CustomTickerCanvasElementTestLabel.d.mts +20 -0
  264. package/dist/labels/CustomTickerCanvasElementTestLabel.d.ts +20 -0
  265. package/dist/labels/CustomTickerCanvasElementTestLabel.js +2792 -0
  266. package/dist/labels/CustomTickerCanvasElementTestLabel.js.map +1 -0
  267. package/dist/labels/CustomTickerCanvasElementTestLabel.mjs +2786 -0
  268. package/dist/labels/CustomTickerCanvasElementTestLabel.mjs.map +1 -0
  269. package/dist/labels/ImagesAnimationsTestLabel.d.mts +9 -0
  270. package/dist/labels/ImagesAnimationsTestLabel.d.ts +9 -0
  271. package/dist/labels/ImagesAnimationsTestLabel.js +3378 -0
  272. package/dist/labels/ImagesAnimationsTestLabel.js.map +1 -0
  273. package/dist/labels/ImagesAnimationsTestLabel.mjs +3372 -0
  274. package/dist/labels/ImagesAnimationsTestLabel.mjs.map +1 -0
  275. package/dist/labels/MarkdownTest.d.mts +9 -0
  276. package/dist/labels/MarkdownTest.d.ts +9 -0
  277. package/dist/labels/MarkdownTest.js +2756 -0
  278. package/dist/labels/MarkdownTest.js.map +1 -0
  279. package/dist/labels/MarkdownTest.mjs +2750 -0
  280. package/dist/labels/MarkdownTest.mjs.map +1 -0
  281. package/dist/labels/StartLabel.d.mts +10 -0
  282. package/dist/labels/StartLabel.d.ts +10 -0
  283. package/dist/labels/StartLabel.js +3736 -0
  284. package/dist/labels/StartLabel.js.map +1 -0
  285. package/dist/labels/StartLabel.mjs +3729 -0
  286. package/dist/labels/StartLabel.mjs.map +1 -0
  287. package/dist/labels/TestConstant.d.mts +17 -0
  288. package/dist/labels/TestConstant.d.ts +17 -0
  289. package/dist/labels/TestConstant.js +1872 -0
  290. package/dist/labels/TestConstant.js.map +1 -0
  291. package/dist/labels/TestConstant.mjs +1856 -0
  292. package/dist/labels/TestConstant.mjs.map +1 -0
  293. package/dist/labels/TickerTestLabel.d.mts +9 -0
  294. package/dist/labels/TickerTestLabel.d.ts +9 -0
  295. package/dist/labels/TickerTestLabel.js +2675 -0
  296. package/dist/labels/TickerTestLabel.js.map +1 -0
  297. package/dist/labels/TickerTestLabel.mjs +2669 -0
  298. package/dist/labels/TickerTestLabel.mjs.map +1 -0
  299. package/dist/labels/index.d.mts +10 -0
  300. package/dist/labels/index.d.ts +10 -0
  301. package/dist/labels/index.js +3736 -0
  302. package/dist/labels/index.js.map +1 -0
  303. package/dist/labels/index.mjs +3729 -0
  304. package/dist/labels/index.mjs.map +1 -0
  305. package/dist/managers/StepManager.d.mts +21 -15
  306. package/dist/managers/StepManager.d.ts +21 -15
  307. package/dist/managers/StepManager.js +610 -251
  308. package/dist/managers/StepManager.js.map +1 -1
  309. package/dist/managers/StepManager.mjs +610 -251
  310. package/dist/managers/StepManager.mjs.map +1 -1
  311. package/dist/managers/WindowManager.d.mts +38 -24
  312. package/dist/managers/WindowManager.d.ts +38 -24
  313. package/dist/managers/WindowManager.js +356 -170
  314. package/dist/managers/WindowManager.js.map +1 -1
  315. package/dist/managers/WindowManager.mjs +352 -170
  316. package/dist/managers/WindowManager.mjs.map +1 -1
  317. package/dist/managers/index.d.mts +15 -14
  318. package/dist/managers/index.d.ts +15 -14
  319. package/dist/managers/index.js +612 -251
  320. package/dist/managers/index.js.map +1 -1
  321. package/dist/managers/index.mjs +612 -251
  322. package/dist/managers/index.mjs.map +1 -1
  323. package/dist/types/CanvasEventNamesType.d.mts +1 -1
  324. package/dist/types/CanvasEventNamesType.d.ts +1 -1
  325. package/dist/types/ChoiceMenuOptionsType.d.mts +2 -2
  326. package/dist/types/ChoiceMenuOptionsType.d.ts +2 -2
  327. package/dist/types/HistoryChoiceMenuOption.d.mts +22 -0
  328. package/dist/types/HistoryChoiceMenuOption.d.ts +22 -0
  329. package/dist/types/HistoryChoiceMenuOption.js +4 -0
  330. package/dist/types/HistoryChoiceMenuOption.mjs +3 -0
  331. package/dist/types/PauseType.d.mts +8 -4
  332. package/dist/types/PauseType.d.ts +8 -4
  333. package/dist/types/PauseType.js +0 -11
  334. package/dist/types/PauseType.js.map +1 -1
  335. package/dist/types/PauseType.mjs +0 -9
  336. package/dist/types/PauseType.mjs.map +1 -1
  337. package/dist/types/RepeatType.d.mts +1 -2
  338. package/dist/types/RepeatType.d.ts +1 -2
  339. package/dist/types/RepeatType.js +0 -4
  340. package/dist/types/RepeatType.js.map +1 -1
  341. package/dist/types/RepeatType.mjs +0 -3
  342. package/dist/types/RepeatType.mjs.map +1 -1
  343. package/dist/types/index.d.mts +5 -4
  344. package/dist/types/index.d.ts +5 -4
  345. package/dist/types/index.js +0 -15
  346. package/dist/types/index.js.map +1 -1
  347. package/dist/types/index.mjs +1 -13
  348. package/dist/types/index.mjs.map +1 -1
  349. package/dist/types/ticker/{TickerFadeAlphaProps.d.mts → FadeAlphaTickerProps.d.mts} +9 -5
  350. package/dist/types/ticker/{TickerFadeAlphaProps.d.ts → FadeAlphaTickerProps.d.ts} +9 -5
  351. package/dist/types/ticker/FadeAlphaTickerProps.js +4 -0
  352. package/dist/types/ticker/FadeAlphaTickerProps.js.map +1 -0
  353. package/dist/types/ticker/FadeAlphaTickerProps.mjs +3 -0
  354. package/dist/types/ticker/FadeAlphaTickerProps.mjs.map +1 -0
  355. package/dist/types/ticker/{TickerMoveProps.d.mts → MoveTickerProps.d.mts} +14 -5
  356. package/dist/types/ticker/{TickerMoveProps.d.ts → MoveTickerProps.d.ts} +14 -5
  357. package/dist/types/ticker/{TickerRotateProps.js → MoveTickerProps.js} +1 -1
  358. package/dist/types/ticker/MoveTickerProps.js.map +1 -0
  359. package/dist/types/ticker/MoveTickerProps.mjs +3 -0
  360. package/dist/types/ticker/MoveTickerProps.mjs.map +1 -0
  361. package/dist/types/ticker/{TickerRotateProps.d.mts → RotateTickerProps.d.mts} +10 -4
  362. package/dist/types/ticker/{TickerRotateProps.d.ts → RotateTickerProps.d.ts} +10 -4
  363. package/dist/types/ticker/RotateTickerProps.js +4 -0
  364. package/dist/types/ticker/RotateTickerProps.js.map +1 -0
  365. package/dist/types/ticker/RotateTickerProps.mjs +3 -0
  366. package/dist/types/ticker/RotateTickerProps.mjs.map +1 -0
  367. package/dist/types/ticker/TagToRemoveAfterType.d.mts +4 -0
  368. package/dist/types/ticker/TagToRemoveAfterType.d.ts +4 -0
  369. package/dist/types/ticker/TagToRemoveAfterType.js +8 -0
  370. package/dist/types/ticker/TagToRemoveAfterType.js.map +1 -0
  371. package/dist/types/ticker/TagToRemoveAfterType.mjs +6 -0
  372. package/dist/types/ticker/TagToRemoveAfterType.mjs.map +1 -0
  373. package/dist/types/ticker/ZoomTickerProps.d.mts +45 -0
  374. package/dist/types/ticker/ZoomTickerProps.d.ts +45 -0
  375. package/dist/types/ticker/ZoomTickerProps.js +4 -0
  376. package/dist/types/ticker/ZoomTickerProps.js.map +1 -0
  377. package/dist/types/ticker/ZoomTickerProps.mjs +3 -0
  378. package/dist/types/ticker/ZoomTickerProps.mjs.map +1 -0
  379. package/dist/types/ticker/index.d.mts +4 -2
  380. package/dist/types/ticker/index.d.ts +4 -2
  381. package/package.json +7 -7
  382. package/dist/classes/ticker/TickerFadeAlpha.d.mts +0 -31
  383. package/dist/classes/ticker/TickerFadeAlpha.d.ts +0 -31
  384. package/dist/classes/ticker/TickerFadeAlpha.js.map +0 -1
  385. package/dist/classes/ticker/TickerFadeAlpha.mjs.map +0 -1
  386. package/dist/classes/ticker/TickerMove.d.mts +0 -29
  387. package/dist/classes/ticker/TickerMove.d.ts +0 -29
  388. package/dist/classes/ticker/TickerMove.js.map +0 -1
  389. package/dist/classes/ticker/TickerMove.mjs.map +0 -1
  390. package/dist/classes/ticker/TickerRotate.d.mts +0 -30
  391. package/dist/classes/ticker/TickerRotate.d.ts +0 -30
  392. package/dist/classes/ticker/TickerRotate.js.map +0 -1
  393. package/dist/classes/ticker/TickerRotate.mjs.map +0 -1
  394. package/dist/functions/ErrorUtility.d.mts +0 -24
  395. package/dist/functions/ErrorUtility.d.ts +0 -24
  396. package/dist/functions/ErrorUtility.js +0 -261
  397. package/dist/functions/ErrorUtility.js.map +0 -1
  398. package/dist/functions/ErrorUtility.mjs +0 -258
  399. package/dist/functions/ErrorUtility.mjs.map +0 -1
  400. package/dist/interface/IClassWithArgsHistory.d.mts +0 -25
  401. package/dist/interface/IClassWithArgsHistory.d.ts +0 -25
  402. package/dist/interface/IClassWithArgsHistory.js +0 -4
  403. package/dist/interface/IClassWithArgsHistory.mjs +0 -3
  404. package/dist/types/ticker/TickerFadeAlphaProps.js +0 -4
  405. package/dist/types/ticker/TickerFadeAlphaProps.mjs +0 -3
  406. package/dist/types/ticker/TickerMoveProps.mjs +0 -3
  407. package/dist/types/ticker/TickerRotateProps.mjs +0 -3
  408. /package/dist/interface/{IClassWithArgsHistory.js.map → CharacterBaseModelProps.js.map} +0 -0
  409. /package/dist/interface/{IClassWithArgsHistory.mjs.map → CharacterBaseModelProps.mjs.map} +0 -0
  410. /package/dist/{types/ticker/TickerFadeAlphaProps.js.map → interface/TickerHistory.js.map} +0 -0
  411. /package/dist/{types/ticker/TickerFadeAlphaProps.mjs.map → interface/TickerHistory.mjs.map} +0 -0
  412. /package/dist/{types/ticker/TickerMoveProps.js.map → interface/TickerTimeoutHistory.js.map} +0 -0
  413. /package/dist/{types/ticker/TickerMoveProps.mjs.map → interface/TickerTimeoutHistory.mjs.map} +0 -0
  414. /package/dist/types/{ticker/TickerRotateProps.js.map → HistoryChoiceMenuOption.js.map} +0 -0
  415. /package/dist/types/{ticker/TickerRotateProps.mjs.map → HistoryChoiceMenuOption.mjs.map} +0 -0
@@ -0,0 +1,1639 @@
1
+ import { Sprite, Container, Application, Text, Assets, Texture } from 'pixi.js';
2
+ import 'deep-diff';
3
+ import sha1 from 'crypto-js/sha1';
4
+
5
+ var __defProp = Object.defineProperty;
6
+ var __defProps = Object.defineProperties;
7
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
8
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
9
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
10
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
11
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
+ var __spreadValues = (a, b) => {
14
+ for (var prop in b || (b = {}))
15
+ if (__hasOwnProp.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ if (__getOwnPropSymbols)
18
+ for (var prop of __getOwnPropSymbols(b)) {
19
+ if (__propIsEnum.call(b, prop))
20
+ __defNormalProp(a, prop, b[prop]);
21
+ }
22
+ return a;
23
+ };
24
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
25
+ var __decorateClass = (decorators, target, key, kind) => {
26
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
27
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
28
+ if (decorator = decorators[i])
29
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
30
+ if (kind && result) __defProp(target, key, result);
31
+ return result;
32
+ };
33
+ var __async = (__this, __arguments, generator) => {
34
+ return new Promise((resolve, reject) => {
35
+ var fulfilled = (value) => {
36
+ try {
37
+ step(generator.next(value));
38
+ } catch (e) {
39
+ reject(e);
40
+ }
41
+ };
42
+ var rejected = (value) => {
43
+ try {
44
+ step(generator.throw(value));
45
+ } catch (e) {
46
+ reject(e);
47
+ }
48
+ };
49
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
50
+ step((generator = generator.apply(__this, __arguments)).next());
51
+ });
52
+ };
53
+
54
+ // src/functions/CanvasUtility.ts
55
+ function getTextureMemory(texture) {
56
+ let sourceTexture = texture.source;
57
+ let textureMemory = {
58
+ image: sourceTexture.label
59
+ };
60
+ return textureMemory;
61
+ }
62
+ function exportCanvasElement(element) {
63
+ return element.memory;
64
+ }
65
+ function importCanvasElement(memory) {
66
+ let element = getCanvasElementInstanceById(memory.pixivnId);
67
+ if (element) {
68
+ element.memory = memory;
69
+ } else {
70
+ throw new Error("[Pixi'VN] The element " + memory.pixivnId + " could not be created");
71
+ }
72
+ return element;
73
+ }
74
+
75
+ // src/classes/canvas/CanvasContainer.ts
76
+ var CANVAS_CONTAINER_ID = "CanvasContainer";
77
+ var CanvasContainer = class extends Container {
78
+ constructor(options) {
79
+ super(options);
80
+ this.pixivnId = CANVAS_CONTAINER_ID;
81
+ this.pixivnId = this.constructor.prototype.pixivnId;
82
+ }
83
+ get memory() {
84
+ let memory = getMemoryContainer(this);
85
+ this.children.forEach((child) => {
86
+ memory.elements.push(exportCanvasElement(child));
87
+ });
88
+ return memory;
89
+ }
90
+ set memory(value) {
91
+ setMemoryContainer(this, value);
92
+ value.elements.forEach((child) => {
93
+ this.addChild(importCanvasElement(child));
94
+ });
95
+ }
96
+ };
97
+ function getMemoryContainer(element) {
98
+ let className = "CanvasContainer";
99
+ if (element.hasOwnProperty("pixivnId")) {
100
+ className = element.pixivnId;
101
+ }
102
+ return {
103
+ pixivnId: className,
104
+ elements: [],
105
+ width: element.width,
106
+ height: element.height,
107
+ isRenderGroup: element.isRenderGroup,
108
+ blendMode: element.blendMode,
109
+ tint: element.tint,
110
+ alpha: element.alpha,
111
+ angle: element.angle,
112
+ renderable: element.renderable,
113
+ rotation: element.rotation,
114
+ scale: { x: element.scale.x, y: element.scale.y },
115
+ pivot: { x: element.pivot.x, y: element.pivot.y },
116
+ position: { x: element.position.x, y: element.position.y },
117
+ skew: { x: element.skew.x, y: element.skew.y },
118
+ visible: element.visible,
119
+ culled: element.culled,
120
+ x: element.x,
121
+ y: element.y,
122
+ boundsArea: element.boundsArea,
123
+ cursor: element.cursor,
124
+ eventMode: element.eventMode,
125
+ interactive: element.interactive,
126
+ interactiveChildren: element.interactiveChildren,
127
+ hitArea: element.hitArea
128
+ };
129
+ }
130
+ function setMemoryContainer(element, memory) {
131
+ memory.width && (element.width = memory.width);
132
+ memory.height && (element.height = memory.height);
133
+ memory.isRenderGroup && (element.isRenderGroup = memory.isRenderGroup);
134
+ memory.blendMode && (element.blendMode = memory.blendMode);
135
+ memory.tint && (element.tint = memory.tint);
136
+ memory.alpha && (element.alpha = memory.alpha);
137
+ memory.angle && (element.angle = memory.angle);
138
+ memory.renderable && (element.renderable = memory.renderable);
139
+ memory.rotation && (element.rotation = memory.rotation);
140
+ if (memory.scale) {
141
+ if (typeof memory.scale === "number") {
142
+ element.scale.set(memory.scale, memory.scale);
143
+ } else {
144
+ element.scale.set(memory.scale.x, memory.scale.y);
145
+ }
146
+ }
147
+ if (memory.pivot) {
148
+ if (typeof memory.pivot === "number") {
149
+ element.pivot.set(memory.pivot, memory.pivot);
150
+ } else {
151
+ element.pivot.set(memory.pivot.x, memory.pivot.y);
152
+ }
153
+ }
154
+ memory.position && element.position.set(memory.position.x, memory.position.y);
155
+ memory.skew && element.skew.set(memory.skew.x, memory.skew.y);
156
+ memory.visible && (element.visible = memory.visible);
157
+ memory.culled && (element.culled = memory.culled);
158
+ memory.x && (element.x = memory.x);
159
+ memory.y && (element.y = memory.y);
160
+ memory.boundsArea && (element.boundsArea = memory.boundsArea);
161
+ memory.cursor && (element.cursor = memory.cursor);
162
+ memory.eventMode && (element.eventMode = memory.eventMode);
163
+ memory.interactive && (element.interactive = memory.interactive);
164
+ memory.interactiveChildren && (element.interactiveChildren = memory.interactiveChildren);
165
+ memory.hitArea && (element.hitArea = memory.hitArea);
166
+ }
167
+ function getTexture(imageUrl) {
168
+ return __async(this, null, function* () {
169
+ if (Assets.cache.has(imageUrl)) {
170
+ return Assets.get(imageUrl);
171
+ }
172
+ return Assets.load(imageUrl).then((texture) => {
173
+ if (!texture) {
174
+ console.error("[Pixi'VN] Texture not found", imageUrl);
175
+ return;
176
+ }
177
+ if (!(texture instanceof Texture)) {
178
+ console.error("[Pixi'VN] File not is a image", imageUrl);
179
+ return;
180
+ }
181
+ return texture;
182
+ }).catch((e) => {
183
+ console.error("[Pixi'VN] Error loading image", e);
184
+ return;
185
+ });
186
+ });
187
+ }
188
+ function getTextStyle(style) {
189
+ let fill = style.fill;
190
+ if (fill instanceof Object) {
191
+ console.warn("[Pixi'VN] CanvasText.style.fill is a FillGradient or FillPattern, this is not supported yet.", fill);
192
+ fill = "#00FF00";
193
+ }
194
+ return {
195
+ align: style.align,
196
+ breakWords: style.breakWords,
197
+ dropShadow: style.dropShadow,
198
+ fill,
199
+ fontFamily: style.fontFamily,
200
+ fontSize: style.fontSize,
201
+ fontStyle: style.fontStyle,
202
+ fontVariant: style.fontVariant,
203
+ fontWeight: style.fontWeight,
204
+ leading: style.leading,
205
+ letterSpacing: style.letterSpacing,
206
+ lineHeight: style.lineHeight,
207
+ padding: style.padding,
208
+ stroke: style.stroke,
209
+ textBaseline: style.textBaseline,
210
+ trim: style.trim,
211
+ whiteSpace: style.whiteSpace,
212
+ wordWrap: style.wordWrap,
213
+ wordWrapWidth: style.wordWrapWidth
214
+ };
215
+ }
216
+
217
+ // src/decorators/EventDecorator.ts
218
+ var registeredEvents = {};
219
+ function getEventTypeById(eventId) {
220
+ try {
221
+ let eventType = registeredEvents[eventId];
222
+ if (!eventType) {
223
+ console.error(`[Pixi'VN] Event ${eventId} not found`);
224
+ return;
225
+ }
226
+ new eventType();
227
+ return eventType;
228
+ } catch (e) {
229
+ console.error(`[Pixi'VN] Error while getting Event ${eventId}`, e);
230
+ return;
231
+ }
232
+ }
233
+ function getEventInstanceById(eventId) {
234
+ try {
235
+ let eventType = registeredEvents[eventId];
236
+ if (!eventType) {
237
+ console.error(`[Pixi'VN] Event ${eventId} not found`);
238
+ return;
239
+ }
240
+ let event = new eventType();
241
+ return event;
242
+ } catch (e) {
243
+ console.error(`[Pixi'VN] Error while getting Event ${eventId}`, e);
244
+ return;
245
+ }
246
+ }
247
+
248
+ // src/classes/canvas/CanvasSprite.ts
249
+ var CANVAS_SPRITE_ID = "CanvasSprite";
250
+ var CanvasSprite = class _CanvasSprite extends Sprite {
251
+ constructor(options) {
252
+ super(options);
253
+ this.pixivnId = CANVAS_SPRITE_ID;
254
+ this._onEvents = {};
255
+ this.pixivnId = this.constructor.prototype.pixivnId;
256
+ }
257
+ get memory() {
258
+ return getMemorySprite(this);
259
+ }
260
+ set memory(value) {
261
+ setMemorySprite(this, value);
262
+ }
263
+ get onEvents() {
264
+ return this._onEvents;
265
+ }
266
+ /**
267
+ * is same function as on(), but it keeps in memory the children.
268
+ * @param event The event type, e.g., 'click', 'mousedown', 'mouseup', 'pointerdown', etc.
269
+ * @param eventClass The class that extends CanvasEvent.
270
+ * @returns
271
+ * @example
272
+ * ```typescript
273
+ * \@eventDecorator()
274
+ * export class EventTest extends CanvasEvent<CanvasSprite> {
275
+ * override fn(event: CanvasEventNamesType, sprite: CanvasSprite): void {
276
+ * if (event === 'pointerdown') {
277
+ * sprite.scale.x *= 1.25;
278
+ * sprite.scale.y *= 1.25;
279
+ * }
280
+ * }
281
+ * }
282
+ * ```
283
+ *
284
+ * ```typescript
285
+ * let sprite = addImage("alien", 'https://pixijs.com/assets/eggHead.png')
286
+ * await sprite.load()
287
+ *
288
+ * sprite.eventMode = 'static';
289
+ * sprite.cursor = 'pointer';
290
+ * sprite.onEvent('pointerdown', EventTest);
291
+ *
292
+ * GameWindowManager.addCanvasElement("bunny", sprite);
293
+ * ```
294
+ */
295
+ onEvent(event, eventClass) {
296
+ let id = eventClass.prototype.id;
297
+ let instance = getEventInstanceById(id);
298
+ this._onEvents[event] = id;
299
+ if (instance) {
300
+ super.on(event, () => {
301
+ instance.fn(event, this);
302
+ });
303
+ }
304
+ return this;
305
+ }
306
+ /**
307
+ * on() does not keep in memory the event class, use onEvent() instead
308
+ * @deprecated
309
+ * @private
310
+ * @param event
311
+ * @param fn
312
+ * @param context
313
+ */
314
+ on(event, fn, context) {
315
+ return super.on(event, fn, context);
316
+ }
317
+ static from(source, skipCache) {
318
+ let sprite = Sprite.from(source, skipCache);
319
+ let mySprite = new _CanvasSprite();
320
+ mySprite.texture = sprite.texture;
321
+ return mySprite;
322
+ }
323
+ };
324
+ function getMemorySprite(element) {
325
+ let temp = getMemoryContainer(element);
326
+ return __spreadProps(__spreadValues({}, temp), {
327
+ pixivnId: element.pixivnId,
328
+ textureImage: getTextureMemory(element.texture),
329
+ anchor: { x: element.anchor.x, y: element.anchor.y },
330
+ roundPixels: element.roundPixels,
331
+ onEvents: element.onEvents
332
+ });
333
+ }
334
+ function setMemorySprite(element, memory) {
335
+ setMemoryContainer(element, memory);
336
+ getTexture(memory.textureImage.image).then((texture) => {
337
+ if (texture) {
338
+ element.texture = texture;
339
+ }
340
+ });
341
+ if (memory.anchor) {
342
+ if (typeof memory.anchor === "number") {
343
+ element.anchor.set(memory.anchor, memory.anchor);
344
+ } else {
345
+ element.anchor.set(memory.anchor.x, memory.anchor.y);
346
+ }
347
+ }
348
+ memory.roundPixels && (element.roundPixels = memory.roundPixels);
349
+ for (let event in memory.onEvents) {
350
+ let id = memory.onEvents[event];
351
+ let instance = getEventTypeById(id);
352
+ if (instance) {
353
+ element.onEvent(event, instance);
354
+ }
355
+ }
356
+ }
357
+
358
+ // src/classes/canvas/CanvasImage.ts
359
+ var CANVAS_IMAGE_ID = "CanvasImage";
360
+ var CanvasImage = class _CanvasImage extends CanvasSprite {
361
+ constructor(options, imageLink) {
362
+ super(options);
363
+ this.pixivnId = CANVAS_IMAGE_ID;
364
+ this.imageLink = "";
365
+ if (imageLink) {
366
+ this.imageLink = imageLink;
367
+ }
368
+ }
369
+ get memory() {
370
+ return __spreadProps(__spreadValues({}, getMemorySprite(this)), {
371
+ pixivnId: this.pixivnId,
372
+ imageLink: this.imageLink
373
+ });
374
+ }
375
+ set memory(memory) {
376
+ setMemorySprite(this, memory);
377
+ this.imageLink = memory.imageLink;
378
+ }
379
+ static from(source, skipCache) {
380
+ let sprite = Sprite.from(source, skipCache);
381
+ let mySprite = new _CanvasImage();
382
+ mySprite.texture = sprite.texture;
383
+ return mySprite;
384
+ }
385
+ /**
386
+ * Load the image from the link and set the texture of the sprite.
387
+ * @param image The link of the image. If it is not set, it will use the imageLink property.
388
+ * @returns A promise that resolves when the image is loaded.
389
+ */
390
+ load(image) {
391
+ return __async(this, null, function* () {
392
+ if (!image) {
393
+ image = this.imageLink;
394
+ }
395
+ return getTexture(this.imageLink).then((texture) => {
396
+ if (texture) {
397
+ this.texture = texture;
398
+ }
399
+ }).catch((e) => {
400
+ console.error("[Pixi'VN] Error into CanvasImage.load()", e);
401
+ });
402
+ });
403
+ }
404
+ };
405
+ var CANVAS_TEXT_ID = "CanvasText";
406
+ var CanvasText = class extends Text {
407
+ constructor(options) {
408
+ super(options);
409
+ this.pixivnId = CANVAS_TEXT_ID;
410
+ this._onEvents = {};
411
+ this.pixivnId = this.constructor.prototype.pixivnId;
412
+ }
413
+ get memory() {
414
+ return getMemoryText(this);
415
+ }
416
+ set memory(value) {
417
+ setMemoryText(this, value);
418
+ }
419
+ get onEvents() {
420
+ return this._onEvents;
421
+ }
422
+ /**
423
+ * is same function as on(), but it keeps in memory the children.
424
+ * @param event The event type, e.g., 'click', 'mousedown', 'mouseup', 'pointerdown', etc.
425
+ * @param eventClass The class that extends CanvasEvent.
426
+ * @returns
427
+ * @example
428
+ * ```typescript
429
+ * \@eventDecorator()
430
+ * export class EventTest extends CanvasEvent<CanvasText> {
431
+ * override fn(event: CanvasEventNamesType, text: CanvasText): void {
432
+ * if (event === 'pointerdown') {
433
+ * text.scale.x *= 1.25;
434
+ * text.scale.y *= 1.25;
435
+ * }
436
+ * }
437
+ * }
438
+ * ```
439
+ *
440
+ * ```typescript
441
+ * const text = new CanvasText();
442
+ * text.text = "Hello World"
443
+ *
444
+ * text.eventMode = 'static';
445
+ * text.cursor = 'pointer';
446
+ * text.onEvent('pointerdown', EventTest);
447
+ *
448
+ * GameWindowManager.addCanvasElement("text", text);
449
+ * ```
450
+ */
451
+ onEvent(event, eventClass) {
452
+ let id = eventClass.prototype.id;
453
+ let instance = getEventInstanceById(id);
454
+ this._onEvents[event] = id;
455
+ if (instance) {
456
+ super.on(event, () => {
457
+ instance.fn(event, this);
458
+ });
459
+ }
460
+ return this;
461
+ }
462
+ /**
463
+ * on() does not keep in memory the event class, use onEvent() instead
464
+ * @deprecated
465
+ * @private
466
+ * @param event
467
+ * @param fn
468
+ * @param context
469
+ */
470
+ on(event, fn, context) {
471
+ return super.on(event, fn, context);
472
+ }
473
+ };
474
+ function getMemoryText(element) {
475
+ let temp = getMemoryContainer(element);
476
+ return __spreadProps(__spreadValues({}, temp), {
477
+ pixivnId: element.pixivnId,
478
+ anchor: { x: element.anchor.x, y: element.anchor.y },
479
+ text: element.text,
480
+ resolution: element.resolution,
481
+ style: getTextStyle(element.style),
482
+ roundPixels: element.roundPixels,
483
+ onEvents: element.onEvents
484
+ });
485
+ }
486
+ function setMemoryText(element, memory) {
487
+ setMemoryContainer(element, memory);
488
+ if (memory.anchor) {
489
+ if (typeof memory.anchor === "number") {
490
+ element.anchor.set(memory.anchor, memory.anchor);
491
+ } else {
492
+ element.anchor.set(memory.anchor.x, memory.anchor.y);
493
+ }
494
+ }
495
+ memory.text && (element.text = memory.text);
496
+ memory.resolution && (element.resolution = memory.resolution);
497
+ memory.style && (element.style = memory.style);
498
+ memory.roundPixels && (element.roundPixels = memory.roundPixels);
499
+ for (let event in memory.onEvents) {
500
+ let id = memory.onEvents[event];
501
+ let instance = getEventTypeById(id);
502
+ if (instance) {
503
+ element.onEvent(event, instance);
504
+ }
505
+ }
506
+ }
507
+
508
+ // src/decorators/CanvasElementDecorator.ts
509
+ var registeredCanvasElement = {};
510
+ function getCanvasElementInstanceById(canvasId) {
511
+ try {
512
+ let eventType = registeredCanvasElement[canvasId];
513
+ if (!eventType) {
514
+ if (canvasId === CANVAS_CONTAINER_ID) {
515
+ eventType = CanvasContainer;
516
+ } else if (canvasId === CANVAS_IMAGE_ID) {
517
+ eventType = CanvasImage;
518
+ } else if (canvasId === CANVAS_SPRITE_ID) {
519
+ eventType = CanvasSprite;
520
+ } else if (canvasId === CANVAS_TEXT_ID) {
521
+ eventType = CanvasText;
522
+ }
523
+ }
524
+ if (!eventType) {
525
+ console.error(`[Pixi'VN] CanvasElement ${canvasId} not found`);
526
+ return;
527
+ }
528
+ let canvasElement = new eventType();
529
+ return canvasElement;
530
+ } catch (e) {
531
+ console.error(`[Pixi'VN] Error while getting CanvasElement ${canvasId}`, e);
532
+ return;
533
+ }
534
+ }
535
+
536
+ // src/classes/ticker/TickerBase.ts
537
+ var TickerBase = class {
538
+ /**
539
+ * @param args The arguments that you want to pass to the ticker.
540
+ * @param duration The duration of the ticker in seconds. If is undefined, the step will end only when the animation is finished (if the animation doesn't have a goal to reach then it won't finish). @default undefined
541
+ * @param priority The priority of the ticker. @default UPDATE_PRIORITY.NORMAL
542
+ */
543
+ constructor(args, duration, priority) {
544
+ /**
545
+ * Get the id of the ticker. This variable is used in the system to get the ticker by id, {@link geTickerInstanceById}
546
+ */
547
+ this.id = "ticker_id_not_set";
548
+ this.args = args;
549
+ this.duration = duration;
550
+ this.priority = priority;
551
+ this.id = this.constructor.prototype.id;
552
+ }
553
+ /**
554
+ * The method that will be called every frame.
555
+ * This method should be overridden and you can use GameWindowManager.addCanvasElement() to get the canvas element of the canvas, and edit them.
556
+ * @param _ticker The ticker that is calling this method
557
+ * @param _args The arguments that you passed when you added the ticker
558
+ * @param _tags The tags of the canvas elements that are connected to this ticker
559
+ * @param _tickerId The id of the ticker. You can use this to get the ticker from the {@link GameWindowManager.currentTickers}
560
+ */
561
+ fn(_ticker, _args, _tags, _tickerId) {
562
+ throw new Error("[Pixi'VN] The method TickerBase.fn() must be overridden");
563
+ }
564
+ };
565
+
566
+ // src/classes/ticker/FadeAlphaTicker.ts
567
+ var FadeAlphaTicker = class extends TickerBase {
568
+ fn(ticker, args, tags, tickerId) {
569
+ let type = args.type === void 0 ? "hide" : args.type;
570
+ let duration = args.duration === void 0 ? 1 : args.duration;
571
+ let speed = 1 / (duration * 60);
572
+ let limit = args.limit === void 0 ? type === "hide" ? 0 : 1 : args.limit;
573
+ let tagToRemoveAfter2 = args.tagToRemoveAfter || [];
574
+ if (typeof tagToRemoveAfter2 === "string") {
575
+ tagToRemoveAfter2 = [tagToRemoveAfter2];
576
+ }
577
+ if (type === "hide" && limit < 0) {
578
+ limit = 0;
579
+ }
580
+ if (type === "show" && limit > 1) {
581
+ limit = 1;
582
+ }
583
+ tags.filter((tag) => {
584
+ var _a;
585
+ let element = GameWindowManager.getCanvasElement(tag);
586
+ if (args.startOnlyIfHaveTexture) {
587
+ if (element && element instanceof Sprite && ((_a = element.texture) == null ? void 0 : _a.label) == "EMPTY") {
588
+ return false;
589
+ }
590
+ }
591
+ return true;
592
+ }).forEach((tag) => {
593
+ let element = GameWindowManager.getCanvasElement(tag);
594
+ if (element && element instanceof Container) {
595
+ if (type === "show" && element.alpha < limit) {
596
+ element.alpha += speed * ticker.deltaTime;
597
+ } else if (type === "hide" && element.alpha > limit) {
598
+ element.alpha -= speed * ticker.deltaTime;
599
+ }
600
+ if (type === "show" && element.alpha >= limit) {
601
+ element.alpha = limit;
602
+ GameWindowManager.onEndOfTicker(tag, this, tagToRemoveAfter2, tickerId);
603
+ } else if (type === "hide" && element.alpha <= limit) {
604
+ element.alpha = limit;
605
+ GameWindowManager.onEndOfTicker(tag, this, tagToRemoveAfter2, tickerId);
606
+ }
607
+ }
608
+ });
609
+ }
610
+ };
611
+ FadeAlphaTicker = __decorateClass([
612
+ tickerDecorator()
613
+ ], FadeAlphaTicker);
614
+
615
+ // src/functions/TickerUtility.ts
616
+ function updateTickerProgression(args, propertyName, progression) {
617
+ if (args[propertyName] === void 0 || !progression || args[propertyName] === progression.limit) {
618
+ return;
619
+ }
620
+ if (typeof args[propertyName] === "number") {
621
+ if (progression.type === "linear") {
622
+ args[propertyName] = getLinearProgression(args[propertyName], progression);
623
+ } else if (progression.type === "exponential") {
624
+ args[propertyName] = getExponentialProgression(args[propertyName], progression);
625
+ }
626
+ } else if (args[propertyName] !== void 0 && typeof args[propertyName] === "object" && args[propertyName].haveOwnProperty("x") && args[propertyName].haveOwnProperty("y") && typeof args[propertyName].x === "number" && typeof args[propertyName].y === "number") {
627
+ if (progression.type === "linear") {
628
+ args[propertyName].x = getLinearProgression(args[propertyName].x, progression);
629
+ args[propertyName].y = getLinearProgression(args[propertyName].y, progression);
630
+ } else if (progression.type === "exponential") {
631
+ args[propertyName].x = getExponentialProgression(args[propertyName].x, progression);
632
+ args[propertyName].y = getExponentialProgression(args[propertyName].y, progression);
633
+ }
634
+ }
635
+ }
636
+ function getLinearProgression(number, progression) {
637
+ if (progression.limit !== void 0) {
638
+ if (number > progression.limit && progression.amt > 0) {
639
+ return progression.limit;
640
+ } else if (number < progression.limit && progression.amt < 0) {
641
+ return progression.limit;
642
+ }
643
+ }
644
+ return number + progression.amt / 60;
645
+ }
646
+ function getExponentialProgression(number, progression) {
647
+ if (progression.limit !== void 0) {
648
+ if (number > progression.limit && progression.percentage > 0) {
649
+ return progression.limit;
650
+ } else if (number < progression.limit && progression.percentage < 0) {
651
+ return progression.limit;
652
+ }
653
+ }
654
+ return number + number * progression.percentage;
655
+ }
656
+
657
+ // src/classes/ticker/MoveTicker.ts
658
+ var MoveTicker = class extends TickerBase {
659
+ fn(ticker, args, tags, tickerId) {
660
+ let xSpeed = 1;
661
+ let ySpeed = 1;
662
+ if (args.speed) {
663
+ if (typeof args.speed === "number") {
664
+ xSpeed = args.speed;
665
+ ySpeed = args.speed;
666
+ } else {
667
+ xSpeed = args.speed.x;
668
+ ySpeed = args.speed.y;
669
+ }
670
+ }
671
+ xSpeed /= 60;
672
+ ySpeed /= 60;
673
+ let destination = args.destination;
674
+ let tagToRemoveAfter2 = args.tagToRemoveAfter || [];
675
+ if (typeof tagToRemoveAfter2 === "string") {
676
+ tagToRemoveAfter2 = [tagToRemoveAfter2];
677
+ }
678
+ tags.filter((tag) => {
679
+ var _a;
680
+ let element = GameWindowManager.getCanvasElement(tag);
681
+ if (args.startOnlyIfHaveTexture) {
682
+ if (element && element instanceof Sprite && ((_a = element.texture) == null ? void 0 : _a.label) == "EMPTY") {
683
+ return false;
684
+ }
685
+ }
686
+ return true;
687
+ }).forEach((tag) => {
688
+ let element = GameWindowManager.getCanvasElement(tag);
689
+ if (element && element instanceof Container) {
690
+ let xDistance = destination.x - element.x > 0 ? 1 : -1;
691
+ if (xDistance != 0) {
692
+ element.x += xDistance * xSpeed * ticker.deltaTime;
693
+ let newDistance = destination.x - element.x;
694
+ if (xDistance < 0 && newDistance > 0 || xDistance > 0 && newDistance < 0) {
695
+ element.x = destination.x;
696
+ }
697
+ }
698
+ let yDistance = destination.y - element.y > 0 ? 1 : -1;
699
+ if (yDistance != 0) {
700
+ element.y += yDistance * ySpeed * ticker.deltaTime;
701
+ let newDistance = destination.y - element.y;
702
+ if (yDistance < 0 && newDistance > 0 || yDistance > 0 && newDistance < 0) {
703
+ element.y = destination.y;
704
+ }
705
+ }
706
+ if (element.x == destination.x && element.y == destination.y) {
707
+ GameWindowManager.onEndOfTicker(tag, this, tagToRemoveAfter2, tickerId);
708
+ }
709
+ }
710
+ });
711
+ if (args.speedProgression)
712
+ updateTickerProgression(args, "speed", args.speedProgression);
713
+ }
714
+ };
715
+ MoveTicker = __decorateClass([
716
+ tickerDecorator()
717
+ ], MoveTicker);
718
+ var RotateTicker = class extends TickerBase {
719
+ fn(ticker, args, tags, tickerId) {
720
+ let speed = (args.speed === void 0 ? 1 : args.speed) / 60;
721
+ let clockwise = args.clockwise === void 0 ? true : args.clockwise;
722
+ let tagToRemoveAfter2 = args.tagToRemoveAfter || [];
723
+ if (typeof tagToRemoveAfter2 === "string") {
724
+ tagToRemoveAfter2 = [tagToRemoveAfter2];
725
+ }
726
+ tags.filter((tag) => {
727
+ var _a;
728
+ let element = GameWindowManager.getCanvasElement(tag);
729
+ if (args.startOnlyIfHaveTexture) {
730
+ if (element && element instanceof Sprite && ((_a = element.texture) == null ? void 0 : _a.label) == "EMPTY") {
731
+ return false;
732
+ }
733
+ }
734
+ return true;
735
+ }).forEach((tag) => {
736
+ let element = GameWindowManager.getCanvasElement(tag);
737
+ if (element && element instanceof Container) {
738
+ if (clockwise)
739
+ element.rotation += speed * ticker.deltaTime;
740
+ else
741
+ element.rotation -= speed * ticker.deltaTime;
742
+ if (speed < 1e-5 && !(args.speedProgression && args.speedProgression.type == "linear" && args.speedProgression.amt != 0)) {
743
+ GameWindowManager.onEndOfTicker(tag, this, tagToRemoveAfter2, tickerId);
744
+ }
745
+ }
746
+ });
747
+ if (args.speedProgression)
748
+ updateTickerProgression(args, "speed", args.speedProgression);
749
+ }
750
+ };
751
+ RotateTicker = __decorateClass([
752
+ tickerDecorator()
753
+ ], RotateTicker);
754
+
755
+ // src/constants.ts
756
+ var Repeat = "repeat";
757
+
758
+ // src/functions/ExportUtility.ts
759
+ function createExportableElement(element) {
760
+ try {
761
+ let elementString = JSON.stringify(element);
762
+ return JSON.parse(elementString);
763
+ } catch (e) {
764
+ console.error("[Pixi'VN] Error creating exportable element", e);
765
+ throw new Error("[Pixi'VN] Error creating exportable element");
766
+ }
767
+ }
768
+
769
+ // src/decorators/TickerDecorator.ts
770
+ var registeredTickers = {};
771
+ function tickerDecorator(name) {
772
+ return function(target) {
773
+ if (!name) {
774
+ name = target.name;
775
+ }
776
+ if (registeredTickers[name]) {
777
+ console.info(`[Pixi'VN] Ticker ${name} already exists, it will be overwritten`);
778
+ }
779
+ target.prototype.id = name;
780
+ registeredTickers[name] = target;
781
+ };
782
+ }
783
+ function geTickerInstanceById(tickerId, args, duration, priority) {
784
+ try {
785
+ let ticker = registeredTickers[tickerId];
786
+ if (!ticker) {
787
+ console.error(`[Pixi'VN] Ticker ${tickerId} not found`);
788
+ return;
789
+ }
790
+ return new ticker(args, duration, priority);
791
+ } catch (e) {
792
+ console.error(`[Pixi'VN] Error while getting Ticker ${tickerId}`, e);
793
+ return;
794
+ }
795
+ }
796
+
797
+ // src/functions/EasterEgg.ts
798
+ function asciiArtLog() {
799
+ console.info(`
800
+ ____ _ _ ___ ___ _
801
+ | _ \\(_)_ _(_| ) \\ / / \\ | |
802
+ | |_) | \\ \\/ / |/ \\ \\ / /| \\| |
803
+ | __/| |> <| | \\ V / | |\\ |
804
+ |_| |_/_/\\_\\_| \\_/ |_| \\_|
805
+ `);
806
+ }
807
+
808
+ // src/types/ticker/TagToRemoveAfterType.ts
809
+ var tagToRemoveAfter = "tagToRemoveAfter";
810
+
811
+ // src/managers/WindowManager.ts
812
+ var _GameWindowManager = class _GameWindowManager {
813
+ constructor() {
814
+ }
815
+ /**
816
+ * The PIXI Application instance.
817
+ * It not recommended to use this property directly.
818
+ */
819
+ static get app() {
820
+ if (!_GameWindowManager._app) {
821
+ throw new Error("[Pixi'VN] GameWindowManager.app is undefined");
822
+ }
823
+ return _GameWindowManager._app;
824
+ }
825
+ /**
826
+ * If the manager is initialized.
827
+ */
828
+ static get isInitialized() {
829
+ return _GameWindowManager._isInitialized;
830
+ }
831
+ static get screen() {
832
+ return _GameWindowManager.app.screen;
833
+ }
834
+ /**
835
+ * Initialize the PIXI Application and the interface div.
836
+ * This method should be called before any other method.
837
+ * @param element The html element where I will put the canvas. Example: document.body
838
+ * @param width The width of the canvas
839
+ * @param height The height of the canvas
840
+ * @param options The options of PIXI Application
841
+ * @example
842
+ * ```typescript
843
+ * const body = document.body
844
+ * if (!body) {
845
+ * throw new Error('body element not found')
846
+ * }
847
+ * await GameWindowManager.initialize(body, 1920, 1080, {
848
+ * backgroundColor: "#303030"
849
+ * })
850
+ * ```
851
+ */
852
+ static initialize(element, width, height, options) {
853
+ return __async(this, null, function* () {
854
+ _GameWindowManager.canvasWidth = width;
855
+ _GameWindowManager.canvasHeight = height;
856
+ _GameWindowManager._app = new Application();
857
+ return _GameWindowManager.app.init(__spreadValues({
858
+ resolution: window.devicePixelRatio || 1,
859
+ autoDensity: true,
860
+ width,
861
+ height
862
+ }, options)).then(() => {
863
+ _GameWindowManager._isInitialized = true;
864
+ this.addCanvasIntoElement(element);
865
+ window.addEventListener("resize", _GameWindowManager.resize);
866
+ _GameWindowManager.resize();
867
+ asciiArtLog();
868
+ });
869
+ });
870
+ }
871
+ /**
872
+ * Add the canvas into a html element.
873
+ * @param element it is the html element where I will put the canvas. Example: document.body
874
+ */
875
+ static addCanvasIntoElement(element) {
876
+ if (_GameWindowManager.isInitialized) {
877
+ element.appendChild(_GameWindowManager.app.canvas);
878
+ } else {
879
+ console.error("[Pixi'VN] GameWindowManager is not initialized");
880
+ }
881
+ }
882
+ /**
883
+ * Initialize the interface div and add it into a html element.
884
+ * @param element it is the html element where I will put the interface div. Example: document.getElementById('root')
885
+ * @example
886
+ * ```tsx
887
+ * const root = document.getElementById('root')
888
+ * if (!root) {
889
+ * throw new Error('root element not found')
890
+ * }
891
+ * GameWindowManager.initializeHTMLLayout(root)
892
+ * const reactRoot = createRoot(GameWindowManager.htmlLayout)
893
+ * reactRoot.render(
894
+ * <App />
895
+ * )
896
+ * ```
897
+ */
898
+ static initializeHTMLLayout(element) {
899
+ let div = document.createElement("div");
900
+ div.style.position = "absolute";
901
+ div.style.pointerEvents = "none";
902
+ element.appendChild(div);
903
+ _GameWindowManager.htmlLayout = div;
904
+ _GameWindowManager.resize();
905
+ }
906
+ /* Resize Metods */
907
+ /**
908
+ * This method returns the scale of the screen.
909
+ */
910
+ static get screenScale() {
911
+ let screenWidth = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);
912
+ let screenHeight = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);
913
+ return Math.min(screenWidth / _GameWindowManager.canvasWidth, screenHeight / _GameWindowManager.canvasHeight);
914
+ }
915
+ /**
916
+ * This method returns the width of the screen enlarged by the scale.
917
+ */
918
+ static get screenWidth() {
919
+ return Math.floor(_GameWindowManager.screenScale * _GameWindowManager.canvasWidth);
920
+ }
921
+ /**
922
+ * This method returns the height of the screen enlarged by the scale.
923
+ */
924
+ static get screenHeight() {
925
+ return Math.floor(_GameWindowManager.screenScale * _GameWindowManager.canvasHeight);
926
+ }
927
+ /**
928
+ * This method returns the horizontal margin of the screen.
929
+ */
930
+ static get horizontalMargin() {
931
+ let screenWidth = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);
932
+ return (screenWidth - _GameWindowManager.screenWidth) / 2;
933
+ }
934
+ /**
935
+ * This method returns the vertical margin of the screen.
936
+ */
937
+ static get verticalMargin() {
938
+ let screenHeight = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);
939
+ return (screenHeight - _GameWindowManager.screenHeight) / 2;
940
+ }
941
+ /**
942
+ * This method is called when the screen is resized.
943
+ */
944
+ static resize() {
945
+ if (_GameWindowManager.isInitialized) {
946
+ let style = _GameWindowManager.app.canvas.style;
947
+ style.width = `${_GameWindowManager.screenWidth}px`;
948
+ style.height = `${_GameWindowManager.screenHeight}px`;
949
+ style.marginLeft = `${_GameWindowManager.horizontalMargin}px`;
950
+ style.marginRight = `${_GameWindowManager.horizontalMargin}px`;
951
+ style.marginTop = `${_GameWindowManager.verticalMargin}px`;
952
+ style.marginBottom = `${_GameWindowManager.verticalMargin}px`;
953
+ }
954
+ if (_GameWindowManager.htmlLayout) {
955
+ _GameWindowManager.htmlLayout.style.width = `${_GameWindowManager.screenWidth}px`;
956
+ _GameWindowManager.htmlLayout.style.height = `${_GameWindowManager.screenHeight}px`;
957
+ _GameWindowManager.htmlLayout.style.marginLeft = `${_GameWindowManager.horizontalMargin}px`;
958
+ _GameWindowManager.htmlLayout.style.marginRight = `${_GameWindowManager.horizontalMargin}px`;
959
+ _GameWindowManager.htmlLayout.style.marginTop = `${_GameWindowManager.verticalMargin}px`;
960
+ _GameWindowManager.htmlLayout.style.marginBottom = `${_GameWindowManager.verticalMargin}px`;
961
+ }
962
+ }
963
+ /* Edit Canvas Elements Methods */
964
+ /**
965
+ * This is a dictionary that contains all Canvas Elements of Canvas, currently.
966
+ */
967
+ static get currentCanvasElements() {
968
+ return _GameWindowManager._children;
969
+ }
970
+ /**
971
+ * Add a canvas element to the canvas.
972
+ * If there is a canvas element with the same tag, it will be removed.
973
+ * @param tag The tag of the canvas element.
974
+ * @param canvasElement The canvas elements to be added.
975
+ * @example
976
+ * ```typescript
977
+ * const texture = await Assets.load('https://pixijs.com/assets/bunny.png');
978
+ * const sprite = CanvasSprite.from(texture);
979
+ * GameWindowManager.addCanvasElement("bunny", sprite);
980
+ * ```
981
+ */
982
+ static addCanvasElement(tag, canvasElement) {
983
+ if (_GameWindowManager._children[tag]) {
984
+ _GameWindowManager.removeCanvasElement(tag);
985
+ }
986
+ _GameWindowManager.app.stage.addChild(canvasElement);
987
+ _GameWindowManager._children[tag] = canvasElement;
988
+ _GameWindowManager.childrenTagsOrder.push(tag);
989
+ }
990
+ /**
991
+ * Remove a canvas element from the canvas.
992
+ * And remove all tickers that are not connected to any canvas element.
993
+ * @param tags The tag of the canvas element to be removed.
994
+ * @returns
995
+ * @example
996
+ * ```typescript
997
+ * GameWindowManager.removeCanvasElement("bunny");
998
+ * ```
999
+ */
1000
+ static removeCanvasElement(tags) {
1001
+ if (typeof tags === "string") {
1002
+ tags = [tags];
1003
+ }
1004
+ tags.forEach((tag) => {
1005
+ if (_GameWindowManager._children[tag]) {
1006
+ _GameWindowManager.app.stage.removeChild(_GameWindowManager._children[tag]);
1007
+ delete _GameWindowManager._children[tag];
1008
+ _GameWindowManager.removeTickerByCanvasElement(tag);
1009
+ }
1010
+ });
1011
+ _GameWindowManager.childrenTagsOrder = _GameWindowManager.childrenTagsOrder.filter((t) => !tags.includes(t));
1012
+ }
1013
+ /**
1014
+ * Get a canvas element by the tag.
1015
+ * @param tag The tag of the canvas element.
1016
+ * @returns The canvas element.
1017
+ * @example
1018
+ * ```typescript
1019
+ * const sprite = GameWindowManager.getCanvasElement<CanvasSprite>("bunny");
1020
+ * ```
1021
+ */
1022
+ static getCanvasElement(tag) {
1023
+ return _GameWindowManager._children[tag];
1024
+ }
1025
+ /**
1026
+ * Check if a DisplayObject is on the canvas.
1027
+ * @param pixiElement The DisplayObject to be checked.
1028
+ * @returns If the DisplayObject is on the canvas.
1029
+ */
1030
+ static canvasElementIsOnCanvas(pixiElement) {
1031
+ return _GameWindowManager.app.stage.children.includes(pixiElement);
1032
+ }
1033
+ /**
1034
+ * Remove all canvas elements from the canvas.
1035
+ * And remove all tickers that are not connected to any canvas element.
1036
+ */
1037
+ static removeCanvasElements() {
1038
+ _GameWindowManager.app.stage.removeChildren();
1039
+ _GameWindowManager._children = {};
1040
+ _GameWindowManager.childrenTagsOrder = [];
1041
+ _GameWindowManager.removeAllTickers();
1042
+ }
1043
+ /**
1044
+ * Edit the tag of a canvas element.
1045
+ * @param oldTag The old tag of the canvas element.
1046
+ * @param newTag The new tag of the canvas element.
1047
+ */
1048
+ static editCanvasElementTag(oldTag, newTag) {
1049
+ if (_GameWindowManager._children[oldTag]) {
1050
+ _GameWindowManager._children[newTag] = _GameWindowManager._children[oldTag];
1051
+ delete _GameWindowManager._children[oldTag];
1052
+ }
1053
+ if (_GameWindowManager._currentTickersSteps[oldTag]) {
1054
+ _GameWindowManager._currentTickersSteps[newTag] = _GameWindowManager._currentTickersSteps[oldTag];
1055
+ delete _GameWindowManager._currentTickersSteps[oldTag];
1056
+ }
1057
+ for (let id in _GameWindowManager._currentTickers) {
1058
+ let ticker = _GameWindowManager._currentTickers[id];
1059
+ if (ticker.canvasElementTags.includes(oldTag)) {
1060
+ ticker.canvasElementTags = ticker.canvasElementTags.map((t) => t === oldTag ? newTag : t);
1061
+ if (ticker.args.hasOwnProperty(tagToRemoveAfter)) {
1062
+ let tagToRemoveAfter2 = ticker.args.tagToRemoveAfter;
1063
+ if (typeof tagToRemoveAfter2 === "string") {
1064
+ tagToRemoveAfter2 = [tagToRemoveAfter2];
1065
+ }
1066
+ if (Array.isArray(tagToRemoveAfter2)) {
1067
+ ticker.args.tagToRemoveAfter = tagToRemoveAfter2.map((t) => t === oldTag ? newTag : t);
1068
+ }
1069
+ }
1070
+ }
1071
+ }
1072
+ for (let timeout in _GameWindowManager._currentTickersTimeouts) {
1073
+ let TickerTimeout = _GameWindowManager._currentTickersTimeouts[timeout];
1074
+ if (TickerTimeout.tags.includes(oldTag)) {
1075
+ TickerTimeout.tags = TickerTimeout.tags.map((t) => t === oldTag ? newTag : t);
1076
+ }
1077
+ }
1078
+ }
1079
+ /** Edit Tickers Methods */
1080
+ /**
1081
+ * Currently tickers that are running.
1082
+ */
1083
+ static get currentTickers() {
1084
+ return _GameWindowManager._currentTickers;
1085
+ }
1086
+ static get currentTickersList() {
1087
+ return Object.values(_GameWindowManager._currentTickers);
1088
+ }
1089
+ static get currentTickersWithoutCreatedBySteps() {
1090
+ return Object.fromEntries(Object.entries(_GameWindowManager._currentTickers).filter(([_, ticker]) => !ticker.createdByTicketStepsId));
1091
+ }
1092
+ /**
1093
+ * The steps of the tickers
1094
+ */
1095
+ static get currentTickersSteps() {
1096
+ return _GameWindowManager._currentTickersSteps;
1097
+ }
1098
+ static generateTickerId(tickerData) {
1099
+ try {
1100
+ return sha1(JSON.stringify(tickerData)).toString() + "_" + Math.random().toString(36).substring(7);
1101
+ } catch (e) {
1102
+ throw new Error(`[Pixi'VN] Error to generate ticker id: ${e}`);
1103
+ }
1104
+ }
1105
+ /**
1106
+ * Run a ticker. You can run multiple addTicker with the same tag and different tickerClasses.
1107
+ * If you run a ticker with the same tag and tickerClass, the old ticker will be removed.
1108
+ * If already exists a sequence of tickers with the same tag, it will be removed.
1109
+ * @param canvasEslementTag The tag of the canvas element that will use the ticker.
1110
+ * @param ticker The ticker class to be run.
1111
+ * @param args The arguments to be used in the ticker.
1112
+ * @param duration The time to be used in the ticker. This number is in seconds. If it is undefined, the ticker will run forever.
1113
+ * @param priority The priority to be used in the ticker.
1114
+ * @returns
1115
+ * @example
1116
+ * ```typescript
1117
+ * GameWindowManager.addTicker("alien", new RotateTicker({ speed: 0.2 }))
1118
+ * ```
1119
+ */
1120
+ static addTicker(canvasElementTag, ticker) {
1121
+ let tickerId = ticker.id;
1122
+ if (typeof canvasElementTag === "string") {
1123
+ canvasElementTag = [canvasElementTag];
1124
+ }
1125
+ if (!geTickerInstanceById(tickerId, ticker.args, ticker.duration, ticker.priority)) {
1126
+ console.error(`[Pixi'VN] Ticker ${tickerId} not found`);
1127
+ return;
1128
+ }
1129
+ let tickerHistory = {
1130
+ fn: () => {
1131
+ },
1132
+ id: tickerId,
1133
+ args: createExportableElement(ticker.args),
1134
+ canvasElementTags: canvasElementTag,
1135
+ priority: ticker.priority,
1136
+ duration: ticker.duration
1137
+ };
1138
+ let id = _GameWindowManager.generateTickerId(tickerHistory);
1139
+ _GameWindowManager.pushTicker(id, tickerHistory, ticker);
1140
+ if (ticker.duration) {
1141
+ let timeout = setTimeout(() => {
1142
+ _GameWindowManager.removeTickerTimeoutInfo(timeout);
1143
+ let tickerTimeoutInfo = _GameWindowManager._currentTickersTimeouts[timeout.toString()];
1144
+ if (tickerTimeoutInfo) {
1145
+ _GameWindowManager.removeTicker(id);
1146
+ }
1147
+ }, ticker.duration * 1e3);
1148
+ _GameWindowManager.addTickerTimeoutInfo(canvasElementTag, tickerId, timeout.toString(), true);
1149
+ }
1150
+ }
1151
+ static pushTicker(id, tickerData, ticker) {
1152
+ _GameWindowManager.removeAssociationBetweenTickerCanvasElement(tickerData.canvasElementTags, ticker);
1153
+ _GameWindowManager._currentTickers[id] = tickerData;
1154
+ tickerData.fn = (t) => {
1155
+ let data = _GameWindowManager._currentTickers[id];
1156
+ if (data) {
1157
+ ticker == null ? void 0 : ticker.fn(t, data.args, data.canvasElementTags, id);
1158
+ }
1159
+ };
1160
+ _GameWindowManager.app.ticker.add(tickerData.fn, void 0, tickerData.priority);
1161
+ }
1162
+ /**
1163
+ * Run a sequence of tickers. If exists a ticker steps with the same tag, it will be removed.
1164
+ * @param tag The tag of canvas element that will use the tickers.
1165
+ * @param steps The steps of the tickers.
1166
+ * @param currentStepNumber The current step number. It is used to continue the sequence of tickers.
1167
+ * @returns
1168
+ * @example
1169
+ * ```typescript
1170
+ * GameWindowManager.addTickersSteps("alien", [
1171
+ * new RotateTicker({ speed: 0.1, clockwise: true }, 2), // 2 seconds
1172
+ * Pause(1), // 1 second
1173
+ * new RotateTicker({ speed: 0.2, clockwise: false }, 2),
1174
+ * Repeat,
1175
+ * ])
1176
+ * ```
1177
+ */
1178
+ static addTickersSteps(tag, steps, currentStepNumber = 0) {
1179
+ if (steps.length == 0) {
1180
+ console.warn("[Pixi'VN] The steps of the tickers is empty");
1181
+ return;
1182
+ }
1183
+ _GameWindowManager.removeTickerStepByCanvasElement(tag);
1184
+ _GameWindowManager._currentTickersSteps[tag] = {
1185
+ currentStepNumber,
1186
+ steps: steps.map((step) => {
1187
+ if (step === Repeat) {
1188
+ return step;
1189
+ }
1190
+ if (step.hasOwnProperty("type") && step.type === "pause") {
1191
+ return step;
1192
+ }
1193
+ let tickerId = step.id;
1194
+ return {
1195
+ ticker: tickerId,
1196
+ args: createExportableElement(step.args),
1197
+ duration: step.duration
1198
+ };
1199
+ })
1200
+ };
1201
+ _GameWindowManager.runTickersSteps(tag);
1202
+ }
1203
+ static restoneTickersSteps(data) {
1204
+ for (let tag in data) {
1205
+ let steps = data[tag];
1206
+ _GameWindowManager._currentTickersSteps[tag] = steps;
1207
+ _GameWindowManager.runTickersSteps(tag);
1208
+ }
1209
+ }
1210
+ static runTickersSteps(tag) {
1211
+ let step = _GameWindowManager._currentTickersSteps[tag].steps[_GameWindowManager._currentTickersSteps[tag].currentStepNumber];
1212
+ if (step === Repeat) {
1213
+ step = _GameWindowManager._currentTickersSteps[tag].steps[0];
1214
+ _GameWindowManager._currentTickersSteps[tag].currentStepNumber = 0;
1215
+ if (step === Repeat) {
1216
+ console.error("[Pixi'VN] TikersSteps has a RepeatType in the first step");
1217
+ return;
1218
+ }
1219
+ }
1220
+ if (step.hasOwnProperty("type") && step.type === "pause") {
1221
+ let timeout = setTimeout(() => {
1222
+ let tickerTimeoutInfo = _GameWindowManager._currentTickersTimeouts[timeout.toString()];
1223
+ if (tickerTimeoutInfo) {
1224
+ tickerTimeoutInfo.tags.forEach((tag2) => {
1225
+ _GameWindowManager.nextTickerStep(tag2);
1226
+ });
1227
+ }
1228
+ _GameWindowManager.removeTickerTimeoutInfo(timeout);
1229
+ }, step.duration * 1e3);
1230
+ _GameWindowManager.addTickerTimeoutInfo(tag, "steps", timeout.toString(), false);
1231
+ return;
1232
+ }
1233
+ let ticker = geTickerInstanceById(step.ticker, step.args, step.duration, step.priority);
1234
+ if (!ticker) {
1235
+ console.error(`[Pixi'VN] Ticker ${step.ticker} not found`);
1236
+ return;
1237
+ }
1238
+ let tickerName = ticker.id;
1239
+ let tickerHistory = {
1240
+ fn: () => {
1241
+ },
1242
+ id: tickerName,
1243
+ args: createExportableElement(ticker.args),
1244
+ canvasElementTags: [tag],
1245
+ priority: ticker.priority,
1246
+ duration: ticker.duration,
1247
+ createdByTicketStepsId: tag
1248
+ };
1249
+ let id = _GameWindowManager.generateTickerId(tickerHistory);
1250
+ _GameWindowManager.pushTicker(id, tickerHistory, ticker);
1251
+ if (ticker.duration) {
1252
+ let timeout = setTimeout(() => {
1253
+ let tickerTimeoutInfo = _GameWindowManager._currentTickersTimeouts[timeout.toString()];
1254
+ if (tickerTimeoutInfo) {
1255
+ _GameWindowManager.removeTicker(id);
1256
+ tickerTimeoutInfo.tags.forEach((tag2) => {
1257
+ _GameWindowManager.nextTickerStep(tag2);
1258
+ });
1259
+ }
1260
+ _GameWindowManager.removeTickerTimeoutInfo(timeout);
1261
+ }, ticker.duration * 1e3);
1262
+ _GameWindowManager.addTickerTimeoutInfo(tag, tickerName, timeout.toString(), false);
1263
+ }
1264
+ }
1265
+ static nextTickerStep(tag) {
1266
+ if (_GameWindowManager._currentTickersSteps[tag]) {
1267
+ let steps = _GameWindowManager._currentTickersSteps[tag];
1268
+ if (steps.currentStepNumber + 1 < steps.steps.length) {
1269
+ steps.currentStepNumber++;
1270
+ _GameWindowManager._currentTickersSteps[tag] = steps;
1271
+ _GameWindowManager.runTickersSteps(tag);
1272
+ } else {
1273
+ _GameWindowManager.removeTickerStepByCanvasElement(tag);
1274
+ }
1275
+ }
1276
+ }
1277
+ static onEndOfTicker(canvasElementTags, ticker, canvasElementTagsToDelete, tickerId) {
1278
+ let tickerData = _GameWindowManager._currentTickers[tickerId];
1279
+ _GameWindowManager.removeAssociationBetweenTickerCanvasElement(canvasElementTags, ticker);
1280
+ _GameWindowManager.removeCanvasElement(canvasElementTagsToDelete);
1281
+ if (tickerData) {
1282
+ _GameWindowManager.removeTicker(tickerId);
1283
+ if (tickerData.duration == void 0 && tickerData.createdByTicketStepsId) {
1284
+ _GameWindowManager.nextTickerStep(tickerData.createdByTicketStepsId);
1285
+ }
1286
+ }
1287
+ }
1288
+ /**
1289
+ * Remove a connection between a canvas element and a ticker.
1290
+ * And remove the ticker if there is no canvas element connected to it.
1291
+ * @param tags The tag of the canvas element that will use the ticker.
1292
+ * @param ticker The ticker class to be removed.
1293
+ * @example
1294
+ * ```typescript
1295
+ * GameWindowManager.removeAssociationBetweenTickerCanvasElement("alien", RotateTicker)
1296
+ * ```
1297
+ */
1298
+ static removeAssociationBetweenTickerCanvasElement(tags, ticker) {
1299
+ let tickerId;
1300
+ if (typeof ticker === "string") {
1301
+ tickerId = ticker;
1302
+ } else if (ticker instanceof TickerBase) {
1303
+ tickerId = ticker.id;
1304
+ } else {
1305
+ tickerId = ticker.prototype.id;
1306
+ }
1307
+ if (typeof tags === "string") {
1308
+ tags = [tags];
1309
+ }
1310
+ for (let id in _GameWindowManager._currentTickers) {
1311
+ let ticker2 = _GameWindowManager._currentTickers[id];
1312
+ if (ticker2.id === tickerId) {
1313
+ _GameWindowManager._currentTickers[id].canvasElementTags = ticker2.canvasElementTags.filter((e) => !tags.includes(e));
1314
+ }
1315
+ }
1316
+ for (let timeout in _GameWindowManager._currentTickersTimeouts) {
1317
+ let TickerTimeout = _GameWindowManager._currentTickersTimeouts[timeout];
1318
+ if (TickerTimeout.ticker === tickerId && TickerTimeout.canBeDeletedBeforeEnd) {
1319
+ _GameWindowManager._currentTickersTimeouts[timeout].tags = TickerTimeout.tags.filter((t) => !tags.includes(t));
1320
+ }
1321
+ }
1322
+ _GameWindowManager.removeTickersWithoutAssociatedCanvasElement();
1323
+ }
1324
+ /**
1325
+ * Remove all tickers that are not connected to any existing canvas element.
1326
+ */
1327
+ static removeTickersWithoutAssociatedCanvasElement() {
1328
+ for (let id in _GameWindowManager._currentTickers) {
1329
+ let ticker = _GameWindowManager._currentTickers[id];
1330
+ ticker.canvasElementTags = ticker.canvasElementTags.filter((e) => _GameWindowManager._children[e]);
1331
+ if (ticker.canvasElementTags.length === 0) {
1332
+ _GameWindowManager.removeTicker(id);
1333
+ }
1334
+ }
1335
+ for (let tag in _GameWindowManager._currentTickersSteps) {
1336
+ if (_GameWindowManager._children[tag] === void 0) {
1337
+ delete _GameWindowManager._currentTickersSteps[tag];
1338
+ }
1339
+ }
1340
+ Object.entries(_GameWindowManager._currentTickersTimeouts).forEach(([timeout, { tags }]) => {
1341
+ if (tags.length === 0) {
1342
+ _GameWindowManager.removeTickerTimeout(timeout);
1343
+ }
1344
+ });
1345
+ }
1346
+ static addTickerTimeoutInfo(tags, ticker, timeout, canBeDeletedBeforeEnd) {
1347
+ if (typeof tags === "string") {
1348
+ tags = [tags];
1349
+ }
1350
+ _GameWindowManager._currentTickersTimeouts[timeout] = {
1351
+ tags,
1352
+ ticker,
1353
+ canBeDeletedBeforeEnd
1354
+ };
1355
+ }
1356
+ static removeTickerTimeoutInfo(timeout) {
1357
+ if (typeof timeout !== "string") {
1358
+ timeout = timeout.toString();
1359
+ }
1360
+ if (_GameWindowManager._currentTickersTimeouts[timeout]) {
1361
+ delete _GameWindowManager._currentTickersTimeouts[timeout];
1362
+ }
1363
+ }
1364
+ static removeTickerTimeout(timeout) {
1365
+ if (typeof timeout !== "string") {
1366
+ timeout = timeout.toString();
1367
+ }
1368
+ clearTimeout(Number(timeout));
1369
+ _GameWindowManager.removeTickerTimeoutInfo(timeout);
1370
+ }
1371
+ static removeTickerTimeoutsByTag(tag, checkCanBeDeletedBeforeEnd) {
1372
+ for (let timeout in _GameWindowManager._currentTickersTimeouts) {
1373
+ let tagsWithoutTagToRemove = _GameWindowManager._currentTickersTimeouts[timeout].tags.filter((t) => t !== tag);
1374
+ if (tagsWithoutTagToRemove.length === 0) {
1375
+ let canBeDeletedBeforeEnd = _GameWindowManager._currentTickersTimeouts[timeout].canBeDeletedBeforeEnd;
1376
+ if (!checkCanBeDeletedBeforeEnd || canBeDeletedBeforeEnd) {
1377
+ _GameWindowManager.removeTickerTimeout(timeout);
1378
+ }
1379
+ } else {
1380
+ _GameWindowManager._currentTickersTimeouts[timeout].tags = tagsWithoutTagToRemove;
1381
+ }
1382
+ }
1383
+ }
1384
+ /**
1385
+ * Remove all tickers from the canvas.
1386
+ */
1387
+ static removeAllTickers() {
1388
+ _GameWindowManager._currentTickersSteps = {};
1389
+ Object.keys(_GameWindowManager._currentTickers).forEach((id) => {
1390
+ _GameWindowManager.removeTicker(id);
1391
+ });
1392
+ _GameWindowManager._currentTickers = {};
1393
+ for (let timeout in _GameWindowManager._currentTickersTimeouts) {
1394
+ _GameWindowManager.removeTickerTimeout(timeout);
1395
+ }
1396
+ }
1397
+ /**
1398
+ * Remove all tickers from a canvas element.
1399
+ * @param tag The tag of the canvas element that will use the ticker.
1400
+ */
1401
+ static removeTickerByCanvasElement(tag) {
1402
+ if (typeof tag === "string") {
1403
+ tag = [tag];
1404
+ }
1405
+ tag.forEach((tag2) => {
1406
+ for (let id in _GameWindowManager._currentTickers) {
1407
+ let ticker = _GameWindowManager._currentTickers[id];
1408
+ if (ticker.canvasElementTags.includes(tag2)) {
1409
+ _GameWindowManager.removeTicker(id);
1410
+ }
1411
+ }
1412
+ if (_GameWindowManager._currentTickersSteps[tag2]) {
1413
+ delete _GameWindowManager._currentTickersSteps[tag2];
1414
+ }
1415
+ _GameWindowManager.removeTickerTimeoutsByTag(tag2, false);
1416
+ delete _GameWindowManager._currentTickersSteps[tag2];
1417
+ });
1418
+ }
1419
+ static removeTickerStepByCanvasElement(tag) {
1420
+ if (_GameWindowManager._currentTickersSteps[tag]) {
1421
+ delete _GameWindowManager._currentTickersSteps[tag];
1422
+ }
1423
+ for (let id in _GameWindowManager._currentTickers) {
1424
+ let ticker = _GameWindowManager._currentTickers[id];
1425
+ if (ticker.createdByTicketStepsId === tag) {
1426
+ _GameWindowManager.removeTicker(id);
1427
+ }
1428
+ }
1429
+ }
1430
+ static removeTicker(tickerId) {
1431
+ let ticker = _GameWindowManager._currentTickers[tickerId];
1432
+ if (ticker) {
1433
+ if (ticker.args.hasOwnProperty(tagToRemoveAfter)) {
1434
+ let tagToRemoveAfter2 = ticker.args.tagToRemoveAfter;
1435
+ _GameWindowManager.removeCanvasElement(tagToRemoveAfter2);
1436
+ }
1437
+ _GameWindowManager.app.ticker.remove(ticker.fn);
1438
+ delete _GameWindowManager._currentTickers[tickerId];
1439
+ }
1440
+ }
1441
+ /**
1442
+ * Clear the canvas and the tickers.
1443
+ */
1444
+ static clear() {
1445
+ _GameWindowManager.removeCanvasElements();
1446
+ }
1447
+ /* Export and Import Methods */
1448
+ /**
1449
+ * Export the canvas and the tickers to a JSON string.
1450
+ * @returns The JSON string.
1451
+ */
1452
+ static exportJson() {
1453
+ return JSON.stringify(this.export());
1454
+ }
1455
+ /**
1456
+ * Export the canvas and the tickers to an object.
1457
+ * @returns The object.
1458
+ */
1459
+ static export() {
1460
+ let currentElements = {};
1461
+ for (let tag in _GameWindowManager._children) {
1462
+ currentElements[tag] = exportCanvasElement(_GameWindowManager._children[tag]);
1463
+ }
1464
+ return {
1465
+ currentTickers: createExportableElement(_GameWindowManager.currentTickersWithoutCreatedBySteps),
1466
+ currentTickersSteps: createExportableElement(_GameWindowManager._currentTickersSteps),
1467
+ currentElements: createExportableElement(currentElements),
1468
+ childrenTagsOrder: createExportableElement(_GameWindowManager.childrenTagsOrder)
1469
+ };
1470
+ }
1471
+ /**
1472
+ * Import the canvas and the tickers from a JSON string.
1473
+ * @param dataString The JSON string.
1474
+ */
1475
+ static importJson(dataString) {
1476
+ _GameWindowManager.import(JSON.parse(dataString));
1477
+ }
1478
+ /**
1479
+ * Import the canvas and the tickers from an object.
1480
+ * @param data The object.
1481
+ */
1482
+ static import(data) {
1483
+ _GameWindowManager.clear();
1484
+ try {
1485
+ if (data.hasOwnProperty("childrenTagsOrder") && data.hasOwnProperty("currentElements")) {
1486
+ let currentElements = data["currentElements"];
1487
+ let childrenTagsOrder = data["childrenTagsOrder"];
1488
+ childrenTagsOrder.forEach((tag) => {
1489
+ if (currentElements[tag]) {
1490
+ let element = importCanvasElement(currentElements[tag]);
1491
+ _GameWindowManager.addCanvasElement(tag, element);
1492
+ _GameWindowManager.childrenTagsOrder.push(tag);
1493
+ }
1494
+ });
1495
+ } else {
1496
+ console.error("[Pixi'VN] The data does not have the properties childrenTagsOrder and currentElements");
1497
+ return;
1498
+ }
1499
+ if (data.hasOwnProperty("currentTickers")) {
1500
+ let currentTickers = data["currentTickers"];
1501
+ for (let id in currentTickers) {
1502
+ let t = currentTickers[id];
1503
+ let tags = t.canvasElementTags;
1504
+ let ticker = geTickerInstanceById(t.id, t.args, t.duration, t.priority);
1505
+ if (ticker) {
1506
+ _GameWindowManager.addTicker(tags, ticker);
1507
+ } else {
1508
+ console.error(`[Pixi'VN] Ticker ${t.id} not found`);
1509
+ }
1510
+ }
1511
+ }
1512
+ if (data.hasOwnProperty("currentTickersSteps")) {
1513
+ let currentTickersSteps = data["currentTickersSteps"];
1514
+ _GameWindowManager.restoneTickersSteps(currentTickersSteps);
1515
+ }
1516
+ } catch (e) {
1517
+ console.error("[Pixi'VN] Error importing data", e);
1518
+ }
1519
+ }
1520
+ };
1521
+ _GameWindowManager._app = void 0;
1522
+ _GameWindowManager._isInitialized = false;
1523
+ _GameWindowManager._children = {};
1524
+ /**
1525
+ * The order of the children tags.
1526
+ */
1527
+ _GameWindowManager.childrenTagsOrder = [];
1528
+ _GameWindowManager._currentTickers = {};
1529
+ _GameWindowManager._currentTickersSteps = {};
1530
+ _GameWindowManager._currentTickersTimeouts = {};
1531
+ var GameWindowManager = _GameWindowManager;
1532
+
1533
+ // src/classes/ticker/ZoomTicker.ts
1534
+ var ZoomTicker = class extends TickerBase {
1535
+ fn(ticker, args, tags, tickerId) {
1536
+ let xSpeed = 0.1;
1537
+ let ySpeed = 0.1;
1538
+ if (args.speed) {
1539
+ if (typeof args.speed === "number") {
1540
+ xSpeed = args.speed;
1541
+ ySpeed = args.speed;
1542
+ } else {
1543
+ xSpeed = args.speed.x;
1544
+ ySpeed = args.speed.y;
1545
+ }
1546
+ }
1547
+ xSpeed /= 60;
1548
+ ySpeed /= 60;
1549
+ let tagToRemoveAfter2 = args.tagToRemoveAfter || [];
1550
+ if (typeof tagToRemoveAfter2 === "string") {
1551
+ tagToRemoveAfter2 = [tagToRemoveAfter2];
1552
+ }
1553
+ let type = args.type || "zoom";
1554
+ let xLimit = type === "zoom" ? Infinity : 0;
1555
+ let yLimit = type === "zoom" ? Infinity : 0;
1556
+ if (args.limit) {
1557
+ if (typeof args.limit === "number") {
1558
+ xLimit = args.limit;
1559
+ yLimit = args.limit;
1560
+ } else {
1561
+ xLimit = args.limit.x;
1562
+ yLimit = args.limit.y;
1563
+ }
1564
+ }
1565
+ tags.filter((tag) => {
1566
+ var _a;
1567
+ let element = GameWindowManager.getCanvasElement(tag);
1568
+ if (args.startOnlyIfHaveTexture) {
1569
+ if (element && element instanceof Sprite && ((_a = element.texture) == null ? void 0 : _a.label) == "EMPTY") {
1570
+ return false;
1571
+ }
1572
+ }
1573
+ return true;
1574
+ }).forEach((tag) => {
1575
+ let element = GameWindowManager.getCanvasElement(tag);
1576
+ if (element && element instanceof Container) {
1577
+ if (type === "zoom" && (element.scale.x < xLimit || element.scale.y < yLimit)) {
1578
+ element.scale.x += xSpeed * ticker.deltaTime;
1579
+ element.scale.y += ySpeed * ticker.deltaTime;
1580
+ } else if (type === "unzoom" && (element.scale.x > xLimit || element.scale.y > yLimit)) {
1581
+ element.scale.x -= xSpeed * ticker.deltaTime;
1582
+ element.scale.y -= ySpeed * ticker.deltaTime;
1583
+ }
1584
+ if (type === "zoom") {
1585
+ if (element.scale.x > xLimit) {
1586
+ element.scale.x = xLimit;
1587
+ }
1588
+ if (element.scale.y > yLimit) {
1589
+ element.scale.y = yLimit;
1590
+ }
1591
+ if (element.scale.x >= xLimit && element.scale.y >= yLimit) {
1592
+ element.scale.x = xLimit;
1593
+ element.scale.y = yLimit;
1594
+ this.onEndOfTicker(tag, tickerId, element, tagToRemoveAfter2);
1595
+ }
1596
+ } else if (type === "unzoom") {
1597
+ if (element.scale.x < xLimit) {
1598
+ element.scale.x = xLimit;
1599
+ }
1600
+ if (element.scale.y < yLimit) {
1601
+ element.scale.y = yLimit;
1602
+ }
1603
+ if (element.scale.x <= xLimit && element.scale.y <= yLimit) {
1604
+ element.scale.x = xLimit;
1605
+ element.scale.y = yLimit;
1606
+ this.onEndOfTicker(tag, tickerId, element, tagToRemoveAfter2);
1607
+ }
1608
+ }
1609
+ if (xSpeed < 1e-5 && ySpeed < 1e-5 && !(args.speedProgression && args.speedProgression.type == "linear" && args.speedProgression.amt != 0)) {
1610
+ this.onEndOfTicker(tag, tickerId, element, tagToRemoveAfter2);
1611
+ }
1612
+ }
1613
+ });
1614
+ if (args.speedProgression)
1615
+ updateTickerProgression(args, "speed", args.speedProgression);
1616
+ }
1617
+ onEndOfTicker(tag, tickerId, _element, tagToRemoveAfter2) {
1618
+ GameWindowManager.onEndOfTicker(tag, this, tagToRemoveAfter2, tickerId);
1619
+ }
1620
+ };
1621
+ ZoomTicker = __decorateClass([
1622
+ tickerDecorator()
1623
+ ], ZoomTicker);
1624
+ var ZoomInOutTicker = class extends ZoomTicker {
1625
+ constructor(props, duration, priority) {
1626
+ super(props, duration, priority);
1627
+ }
1628
+ onEndOfTicker(tag, tickerId, element, tagToRemoveAfter2) {
1629
+ if (element.children.length > 0) {
1630
+ let elementChild = element.children[0];
1631
+ GameWindowManager.addCanvasElement(tag, elementChild);
1632
+ }
1633
+ super.onEndOfTicker(tag, tickerId, element, tagToRemoveAfter2);
1634
+ }
1635
+ };
1636
+
1637
+ export { ZoomInOutTicker, ZoomTicker as default };
1638
+ //# sourceMappingURL=out.js.map
1639
+ //# sourceMappingURL=ZoomTicker.mjs.map