isaacscript-common 14.1.3 → 14.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +919 -141
- package/dist/isaacscript-common.lua +4752 -1790
- package/dist/src/callbacks.d.ts +102 -20
- package/dist/src/callbacks.d.ts.map +1 -1
- package/dist/src/callbacks.lua +124 -1
- package/dist/src/classes/ModFeature.d.ts.map +1 -1
- package/dist/src/classes/ModFeature.lua +22 -1
- package/dist/src/classes/ModUpgraded.d.ts +10 -5
- package/dist/src/classes/ModUpgraded.d.ts.map +1 -1
- package/dist/src/classes/ModUpgraded.lua +30 -11
- package/dist/src/classes/callbacks/PostCustomRevive.d.ts +5 -2
- package/dist/src/classes/callbacks/PostCustomRevive.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PostCustomRevive.lua +12 -4
- package/dist/src/classes/callbacks/PostGridEntityBroken.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCollision.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomBroken.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomCollision.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomInit.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomRemove.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.lua +17 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomStateChanged.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomUpdate.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityInit.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityRemove.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostGridEntityRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostGridEntityRender.lua +17 -0
- package/dist/src/classes/callbacks/PostGridEntityStateChanged.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityUpdate.lua +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.lua +3 -4
- package/dist/src/classes/callbacks/PostItemDischarge.d.ts +43 -0
- package/dist/src/classes/callbacks/PostItemDischarge.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostItemDischarge.lua +113 -0
- package/dist/src/classes/callbacks/PostItemPickup.d.ts +6 -0
- package/dist/src/classes/callbacks/PostItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostItemPickup.lua +17 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts +14 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.lua +33 -0
- package/dist/src/classes/callbacks/PostPickupCollect.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupCollect.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupCollect.lua +35 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.lua +32 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts +13 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.lua +33 -0
- package/dist/src/classes/callbacks/PostPitUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPitUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPitUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts +15 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.lua +52 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts +16 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.lua +94 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts +15 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.lua +37 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts +6 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.lua +17 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts +6 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.lua +17 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts +8 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.lua +39 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts +13 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.lua +29 -0
- package/dist/src/classes/callbacks/PostPoopRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPoopRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPoopRender.lua +24 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.lua +24 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostPurchase.d.ts +18 -0
- package/dist/src/classes/callbacks/PostPurchase.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPurchase.lua +56 -0
- package/dist/src/classes/callbacks/PostRockRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostRockRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostRockRender.lua +24 -0
- package/dist/src/classes/callbacks/PostRockUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostRockUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostRockUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostSacrifice.d.ts +15 -0
- package/dist/src/classes/callbacks/PostSacrifice.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSacrifice.lua +52 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotCollision.d.ts +7 -0
- package/dist/src/classes/callbacks/PostSlotCollision.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotCollision.lua +25 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts +14 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.lua +65 -0
- package/dist/src/classes/callbacks/PostSlotInit.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotInit.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotInit.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotRender.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.lua +17 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostTNTRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostTNTRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTNTRender.lua +24 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostTearInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostTearInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTearInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.lua +30 -0
- package/dist/src/classes/callbacks/PostTransformation.d.ts +18 -0
- package/dist/src/classes/callbacks/PostTransformation.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTransformation.lua +53 -0
- package/dist/src/classes/callbacks/PreBerserkDeath.d.ts +1 -1
- package/dist/src/classes/callbacks/PreBerserkDeath.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PreBerserkDeath.lua +3 -4
- package/dist/src/classes/callbacks/PreItemPickup.d.ts +6 -0
- package/dist/src/classes/callbacks/PreItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PreItemPickup.lua +17 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts +11 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.lua +19 -0
- package/dist/src/classes/callbacks/validation/{CustomCallbackRevive.d.ts → CustomCallbackNPC.d.ts} +4 -4
- package/dist/src/classes/callbacks/validation/CustomCallbackNPC.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackNPC.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts +12 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts +5 -2
- package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts.map +1 -1
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts +12 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSpikes.lua +4 -4
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.lua +19 -0
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts +1 -1
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.lua +27 -30
- package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts +2 -2
- package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/CustomRevive.lua +6 -6
- package/dist/src/classes/features/callbackLogic/EsauJrDetection.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.lua +3 -18
- package/dist/src/classes/features/callbackLogic/GridEntityCollisionDetection.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts +12 -0
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.lua +33 -0
- package/dist/src/classes/features/callbackLogic/{GridEntityDetection.d.ts → GridEntityUpdateDetection.d.ts} +3 -3
- package/dist/src/classes/features/callbackLogic/GridEntityUpdateDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/{GridEntityDetection.lua → GridEntityUpdateDetection.lua} +11 -14
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts +20 -0
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.lua +60 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts +47 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.lua +154 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts +18 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.lua +51 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts +17 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.lua +45 -0
- package/dist/src/classes/features/other/RunInNFrames.d.ts.map +1 -1
- package/dist/src/classes/features/other/RunInNFrames.lua +9 -0
- package/dist/src/classes/features/other/SaveDataManager.d.ts +215 -0
- package/dist/src/classes/features/other/SaveDataManager.d.ts.map +1 -0
- package/dist/src/classes/features/other/SaveDataManager.lua +190 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts +6 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.lua +98 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts +6 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.lua +81 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts +7 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.lua +69 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts +5 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.lua +46 -0
- package/dist/src/classes/private/CustomCallback.d.ts +2 -3
- package/dist/src/classes/private/CustomCallback.d.ts.map +1 -1
- package/dist/src/classes/private/CustomCallback.lua +2 -5
- package/dist/src/classes/private/Feature.d.ts +1 -0
- package/dist/src/classes/private/Feature.d.ts.map +1 -1
- package/dist/src/classes/private/Feature.lua +1 -0
- package/dist/src/core/upgradeMod.d.ts.map +1 -1
- package/dist/src/decorators.d.ts +1 -1
- package/dist/src/decorators.d.ts.map +1 -1
- package/dist/src/decorators.lua +6 -8
- package/dist/src/enums/ISCFeature.d.ts +15 -9
- package/dist/src/enums/ISCFeature.d.ts.map +1 -1
- package/dist/src/enums/ISCFeature.lua +30 -9
- package/dist/src/enums/ModCallbackCustom.d.ts +34 -20
- package/dist/src/enums/ModCallbackCustom.d.ts.map +1 -1
- package/dist/src/enums/ModCallbackCustom2.d.ts +61 -20
- package/dist/src/enums/ModCallbackCustom2.d.ts.map +1 -1
- package/dist/src/enums/ModCallbackCustom2.lua +102 -20
- package/dist/src/enums/{private/SerializationBrand.d.ts → SerializationBrand.d.ts} +6 -1
- package/dist/src/enums/SerializationBrand.d.ts.map +1 -0
- package/dist/src/enums/{private/SerializationBrand.lua → SerializationBrand.lua} +1 -0
- package/dist/src/features/customItemPool.d.ts +52 -0
- package/dist/src/features/customItemPool.d.ts.map +1 -0
- package/dist/src/features/customItemPool.lua +111 -0
- package/dist/src/features/deployJSONRoom.d.ts +6 -4
- package/dist/src/features/deployJSONRoom.d.ts.map +1 -1
- package/dist/src/features/deployJSONRoom.lua +6 -4
- package/dist/src/features/fadeInRemover.d.ts.map +1 -1
- package/dist/src/features/fadeInRemover.lua +4 -16
- package/dist/src/features/saveDataManager/exports.d.ts +14 -4
- package/dist/src/features/saveDataManager/exports.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/exports.lua +38 -0
- package/dist/src/features/saveDataManager/load.d.ts +2 -1
- package/dist/src/features/saveDataManager/load.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/load.lua +10 -4
- package/dist/src/features/saveDataManager/main.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/main.lua +12 -5
- package/dist/src/features/saveDataManager/maps.d.ts +14 -0
- package/dist/src/features/saveDataManager/maps.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/maps.lua +7 -0
- package/dist/src/features.d.ts +31 -12
- package/dist/src/features.d.ts.map +1 -1
- package/dist/src/features.lua +24 -6
- package/dist/src/functions/array.d.ts.map +1 -1
- package/dist/src/functions/array.lua +4 -5
- package/dist/src/functions/bitSet128.d.ts +2 -2
- package/dist/src/functions/bitSet128.lua +3 -3
- package/dist/src/functions/color.d.ts +2 -2
- package/dist/src/functions/color.lua +3 -3
- package/dist/src/functions/decorators.d.ts +21 -0
- package/dist/src/functions/decorators.d.ts.map +1 -1
- package/dist/src/functions/deepCopy.d.ts +11 -4
- package/dist/src/functions/deepCopy.d.ts.map +1 -1
- package/dist/src/functions/deepCopy.lua +84 -32
- package/dist/src/functions/deepCopyTests.lua +1 -1
- package/dist/src/functions/initArray.d.ts +4 -4
- package/dist/src/functions/initArray.d.ts.map +1 -1
- package/dist/src/functions/initArray.lua +6 -12
- package/dist/src/functions/jsonRoom.d.ts +11 -0
- package/dist/src/functions/jsonRoom.d.ts.map +1 -1
- package/dist/src/functions/jsonRoom.lua +11 -0
- package/dist/src/functions/kColor.d.ts +2 -2
- package/dist/src/functions/kColor.lua +3 -3
- package/dist/src/functions/merge.d.ts +40 -0
- package/dist/src/functions/merge.d.ts.map +1 -0
- package/dist/src/{features/saveDataManager → functions}/merge.lua +84 -37
- package/dist/src/functions/mergeTests.d.ts +1 -2
- package/dist/src/functions/mergeTests.d.ts.map +1 -1
- package/dist/src/functions/mergeTests.lua +3 -4
- package/dist/src/functions/rng.d.ts +2 -2
- package/dist/src/functions/rng.lua +3 -3
- package/dist/src/functions/serialization.d.ts.map +1 -1
- package/dist/src/functions/serialization.lua +22 -0
- package/dist/src/functions/tstlClass.d.ts +0 -10
- package/dist/src/functions/tstlClass.d.ts.map +1 -1
- package/dist/src/functions/tstlClass.lua +2 -42
- package/dist/src/functions/vector.d.ts +2 -2
- package/dist/src/functions/vector.lua +3 -3
- package/dist/src/functions/weighted.d.ts +12 -1
- package/dist/src/functions/weighted.d.ts.map +1 -1
- package/dist/src/functions/weighted.lua +27 -10
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.lua +24 -0
- package/dist/src/interfaces/SaveData.d.ts +3 -7
- package/dist/src/interfaces/SaveData.d.ts.map +1 -1
- package/dist/src/interfaces/SaveData.lua +0 -11
- package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts +195 -2
- package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts.map +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts.map +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.lua +1 -1
- package/dist/src/types/AnyClass.d.ts +2 -0
- package/dist/src/types/AnyClass.d.ts.map +1 -0
- package/dist/src/types/AnyClass.lua +2 -0
- package/dist/src/types/AnyFunction.d.ts +6 -0
- package/dist/src/types/AnyFunction.d.ts.map +1 -0
- package/dist/src/types/AnyFunction.lua +2 -0
- package/dist/src/types/FunctionTuple.d.ts +2 -4
- package/dist/src/types/FunctionTuple.d.ts.map +1 -1
- package/dist/src/types/HasFunction.d.ts +5 -0
- package/dist/src/types/HasFunction.d.ts.map +1 -0
- package/dist/src/types/HasFunction.lua +2 -0
- package/package.json +1 -1
- package/src/callbacks.ts +88 -5
- package/src/classes/ModFeature.ts +31 -1
- package/src/classes/ModUpgraded.ts +49 -21
- package/src/classes/callbacks/PostCustomRevive.ts +22 -2
- package/src/classes/callbacks/PostGridEntityBroken.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCollision.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomBroken.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomCollision.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomInit.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomRemove.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomRender.ts +11 -0
- package/src/classes/callbacks/PostGridEntityCustomStateChanged.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomUpdate.ts +1 -1
- package/src/classes/callbacks/PostGridEntityInit.ts +1 -1
- package/src/classes/callbacks/PostGridEntityRemove.ts +1 -1
- package/src/classes/callbacks/PostGridEntityRender.ts +11 -0
- package/src/classes/callbacks/PostGridEntityStateChanged.ts +1 -1
- package/src/classes/callbacks/PostGridEntityUpdate.ts +1 -1
- package/src/classes/callbacks/PostHolyMantleRemoved.ts +5 -8
- package/src/classes/callbacks/PostItemDischarge.ts +181 -0
- package/src/classes/callbacks/PostItemPickup.ts +11 -0
- package/src/classes/callbacks/PostLaserInitLate.ts +28 -0
- package/src/classes/callbacks/PostNPCInitLate.ts +28 -0
- package/src/classes/callbacks/PostNPCStateChanged.ts +37 -0
- package/src/classes/callbacks/PostPickupCollect.ts +37 -0
- package/src/classes/callbacks/PostPickupInitFirst.ts +34 -0
- package/src/classes/callbacks/PostPickupInitLate.ts +28 -0
- package/src/classes/callbacks/PostPickupStateChanged.ts +35 -0
- package/src/classes/callbacks/PostPitUpdate.ts +21 -0
- package/src/classes/callbacks/PostPlayerChangeHealth.ts +57 -0
- package/src/classes/callbacks/PostPlayerChangeStat.ts +102 -0
- package/src/classes/callbacks/PostPlayerChangeType.ts +44 -0
- package/src/classes/callbacks/PostPlayerCollectibleAdded.ts +11 -0
- package/src/classes/callbacks/PostPlayerCollectibleRemoved.ts +11 -0
- package/src/classes/callbacks/PostPlayerInitFirst.ts +44 -0
- package/src/classes/callbacks/PostPlayerInitLate.ts +32 -0
- package/src/classes/callbacks/PostPoopRender.ts +21 -0
- package/src/classes/callbacks/PostPoopUpdate.ts +21 -0
- package/src/classes/callbacks/PostPressurePlateRender.ts +21 -0
- package/src/classes/callbacks/PostPressurePlateUpdate.ts +21 -0
- package/src/classes/callbacks/PostProjectileInitLate.ts +28 -0
- package/src/classes/callbacks/PostPurchase.ts +87 -0
- package/src/classes/callbacks/PostRockRender.ts +21 -0
- package/src/classes/callbacks/PostRockUpdate.ts +21 -0
- package/src/classes/callbacks/PostSacrifice.ts +89 -0
- package/src/classes/callbacks/PostSlotAnimationChanged.ts +11 -0
- package/src/classes/callbacks/PostSlotCollision.ts +26 -0
- package/src/classes/callbacks/PostSlotDestroyed.ts +79 -0
- package/src/classes/callbacks/PostSlotInit.ts +11 -0
- package/src/classes/callbacks/PostSlotRender.ts +11 -0
- package/src/classes/callbacks/PostSlotUpdate.ts +11 -0
- package/src/classes/callbacks/PostSpikesUpdate.ts +21 -0
- package/src/classes/callbacks/PostTNTRender.ts +21 -0
- package/src/classes/callbacks/PostTNTUpdate.ts +21 -0
- package/src/classes/callbacks/PostTearInitLate.ts +28 -0
- package/src/classes/callbacks/PostTearInitVeryLate.ts +33 -0
- package/src/classes/callbacks/PostTransformation.ts +71 -0
- package/src/classes/callbacks/PreBerserkDeath.ts +5 -8
- package/src/classes/callbacks/PreItemPickup.ts +11 -0
- package/src/classes/callbacks/validation/CustomCallbackCollectibleType.ts +32 -0
- package/src/classes/callbacks/validation/CustomCallbackItemPickup.ts +48 -0
- package/src/classes/callbacks/validation/CustomCallbackLaser.ts +27 -0
- package/src/classes/callbacks/validation/CustomCallbackNPC.ts +34 -0
- package/src/classes/callbacks/validation/CustomCallbackPickup.ts +41 -0
- package/src/classes/callbacks/validation/CustomCallbackPlayer.ts +25 -2
- package/src/classes/callbacks/validation/CustomCallbackPoop.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackPressurePlate.ts +31 -0
- package/src/classes/callbacks/validation/CustomCallbackProjectile.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackRock.ts +30 -0
- package/src/classes/callbacks/validation/CustomCallbackSlot.ts +37 -0
- package/src/classes/callbacks/validation/CustomCallbackSpikes.ts +4 -4
- package/src/classes/callbacks/validation/CustomCallbackTNT.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackTear.ts +27 -0
- package/src/classes/features/callbackLogic/CustomGridEntities.ts +32 -36
- package/src/classes/features/callbackLogic/CustomRevive.ts +14 -21
- package/src/classes/features/callbackLogic/EsauJrDetection.ts +0 -4
- package/src/classes/features/callbackLogic/GameReorderedCallbacks.ts +7 -9
- package/src/classes/features/callbackLogic/GridEntityCollisionDetection.ts +0 -4
- package/src/classes/features/callbackLogic/GridEntityRenderDetection.ts +42 -0
- package/src/classes/features/callbackLogic/{GridEntityDetection.ts → GridEntityUpdateDetection.ts} +4 -20
- package/src/classes/features/callbackLogic/ItemPickupDetection.ts +91 -0
- package/src/classes/features/callbackLogic/PlayerCollectibleDetection.ts +245 -0
- package/src/classes/features/callbackLogic/SlotRenderDetection.ts +64 -0
- package/src/classes/features/callbackLogic/SlotUpdateDetection.ts +57 -0
- package/src/classes/features/other/RunInNFrames.ts +7 -0
- package/src/classes/features/other/SaveDataManager.ts +492 -0
- package/src/classes/features/other/saveDataManager/glowingHourGlass.ts +138 -0
- package/src/classes/features/other/saveDataManager/loadFromDisk.ts +99 -0
- package/src/classes/features/other/saveDataManager/restoreDefaults.ts +116 -0
- package/src/classes/features/other/saveDataManager/saveToDisk.ts +70 -0
- package/src/classes/private/CustomCallback.ts +2 -6
- package/src/classes/private/Feature.ts +1 -0
- package/src/core/upgradeMod.ts +2 -4
- package/src/decorators.ts +17 -19
- package/src/enums/ISCFeature.ts +44 -39
- package/src/enums/ModCallbackCustom.ts +34 -20
- package/src/enums/ModCallbackCustom2.ts +53 -5
- package/src/enums/{private/SerializationBrand.ts → SerializationBrand.ts} +8 -2
- package/src/features/customItemPool.ts +133 -0
- package/src/features/deployJSONRoom.ts +6 -4
- package/src/features/fadeInRemover.ts +4 -22
- package/src/features/saveDataManager/exports.ts +62 -3
- package/src/features/saveDataManager/load.ts +4 -1
- package/src/features/saveDataManager/main.ts +5 -3
- package/src/features/saveDataManager/maps.ts +16 -0
- package/src/features.ts +39 -4
- package/src/functions/array.ts +8 -9
- package/src/functions/bitSet128.ts +3 -3
- package/src/functions/color.ts +3 -3
- package/src/functions/decorators.ts +22 -0
- package/src/functions/deepCopy.ts +83 -17
- package/src/functions/deepCopyTests.ts +1 -1
- package/src/functions/initArray.ts +6 -11
- package/src/functions/jsonRoom.ts +11 -0
- package/src/functions/kColor.ts +3 -3
- package/src/{features/saveDataManager → functions}/merge.ts +79 -45
- package/src/functions/mergeTests.ts +2 -3
- package/src/functions/rng.ts +3 -3
- package/src/functions/serialization.ts +25 -1
- package/src/functions/table.ts +1 -1
- package/src/functions/tstlClass.ts +3 -57
- package/src/functions/vector.ts +3 -3
- package/src/functions/weighted.ts +28 -11
- package/src/index.ts +5 -0
- package/src/interfaces/SaveData.ts +3 -34
- package/src/interfaces/private/AddCallbackParametersCustom2.ts +298 -7
- package/src/objects/isaacAPIClassTypeToBrand.ts +1 -1
- package/src/types/AnyClass.ts +1 -0
- package/src/types/AnyFunction.ts +5 -0
- package/src/types/FunctionTuple.ts +3 -4
- package/src/types/HasFunction.ts +7 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRevive.d.ts.map +0 -1
- package/dist/src/classes/callbacks/validation/CustomCallbackRevive.lua +0 -19
- package/dist/src/classes/features/callbackLogic/GridEntityDetection.d.ts.map +0 -1
- package/dist/src/enums/private/SerializationBrand.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/merge.d.ts +0 -26
- package/dist/src/features/saveDataManager/merge.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/serializationBrands.d.ts +0 -2
- package/dist/src/features/saveDataManager/serializationBrands.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/serializationBrands.lua +0 -19
- package/dist/src/indexLua.d.ts +0 -199
- package/dist/src/indexLua.d.ts.map +0 -1
- package/dist/src/indexLua.lua +0 -1354
- package/src/classes/callbacks/validation/CustomCallbackRevive.ts +0 -27
- package/src/features/saveDataManager/serializationBrands.ts +0 -16
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ActiveSlot,
|
|
3
|
+
CollectibleType,
|
|
4
|
+
EntityType,
|
|
5
|
+
ModCallback,
|
|
6
|
+
SuckerVariant,
|
|
7
|
+
} from "isaac-typescript-definitions";
|
|
8
|
+
import { game } from "../../core/cachedClasses";
|
|
9
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
10
|
+
import { getTotalCharge } from "../../functions/charge";
|
|
11
|
+
import { getEnumValues } from "../../functions/enums";
|
|
12
|
+
import {
|
|
13
|
+
defaultMapGetPlayer,
|
|
14
|
+
mapGetPlayer,
|
|
15
|
+
mapSetPlayer,
|
|
16
|
+
} from "../../functions/playerDataStructures";
|
|
17
|
+
import { asNumber } from "../../functions/types";
|
|
18
|
+
import { PlayerIndex } from "../../types/PlayerIndex";
|
|
19
|
+
import { DefaultMap } from "../DefaultMap";
|
|
20
|
+
import {
|
|
21
|
+
CustomCallback,
|
|
22
|
+
FireArgs,
|
|
23
|
+
OptionalArgs,
|
|
24
|
+
} from "../private/CustomCallback";
|
|
25
|
+
|
|
26
|
+
type T = ModCallbackCustom2.POST_ITEM_DISCHARGE;
|
|
27
|
+
|
|
28
|
+
// Unfortunately, we cannot use a nested `DefaultMap` here.
|
|
29
|
+
type ActiveSlotToCollectibleTypeMap = Map<ActiveSlot, CollectibleType>;
|
|
30
|
+
type ActiveSlotToChargeMap = Map<ActiveSlot, int>;
|
|
31
|
+
|
|
32
|
+
export class PostItemDischarge extends CustomCallback<T> {
|
|
33
|
+
public override v = {
|
|
34
|
+
run: {
|
|
35
|
+
playersActiveItemMap: new DefaultMap<
|
|
36
|
+
PlayerIndex,
|
|
37
|
+
ActiveSlotToCollectibleTypeMap
|
|
38
|
+
>(() => new Map()),
|
|
39
|
+
playersActiveChargeMap: new DefaultMap<
|
|
40
|
+
PlayerIndex,
|
|
41
|
+
ActiveSlotToChargeMap
|
|
42
|
+
>(() => new Map()),
|
|
43
|
+
},
|
|
44
|
+
|
|
45
|
+
room: {
|
|
46
|
+
playersBulbLastCollisionFrame: new Map<PlayerIndex, int>(),
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
constructor() {
|
|
51
|
+
super();
|
|
52
|
+
|
|
53
|
+
this.callbacksUsed = [
|
|
54
|
+
[ModCallback.POST_PEFFECT_UPDATE, [this.postPEffectUpdate]], // 4
|
|
55
|
+
[
|
|
56
|
+
ModCallback.PRE_NPC_COLLISION,
|
|
57
|
+
[this.preNPCCollisionSucker, EntityType.SUCKER],
|
|
58
|
+
], // 30
|
|
59
|
+
];
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// eslint-disable-next-line class-methods-use-this
|
|
63
|
+
protected override shouldFire(
|
|
64
|
+
fireArgs: FireArgs<T>,
|
|
65
|
+
optionalArgs: OptionalArgs<T>,
|
|
66
|
+
): boolean {
|
|
67
|
+
const [callbackCollectibleType] = optionalArgs;
|
|
68
|
+
if (callbackCollectibleType === undefined) {
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const [_player, collectibleType] = fireArgs;
|
|
73
|
+
return collectibleType === callbackCollectibleType;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// ModCallback.POST_PEFFECT (4)
|
|
77
|
+
private postPEffectUpdate = (player: EntityPlayer) => {
|
|
78
|
+
const activeItemMap = defaultMapGetPlayer(
|
|
79
|
+
this.v.run.playersActiveItemMap,
|
|
80
|
+
player,
|
|
81
|
+
);
|
|
82
|
+
const chargeMap = defaultMapGetPlayer(
|
|
83
|
+
this.v.run.playersActiveChargeMap,
|
|
84
|
+
player,
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
for (const activeSlot of getEnumValues(ActiveSlot)) {
|
|
88
|
+
const currentActiveItem = player.GetActiveItem();
|
|
89
|
+
let previousActiveItem = activeItemMap.get(activeSlot);
|
|
90
|
+
if (previousActiveItem === undefined) {
|
|
91
|
+
previousActiveItem = currentActiveItem;
|
|
92
|
+
}
|
|
93
|
+
activeItemMap.set(activeSlot, currentActiveItem);
|
|
94
|
+
|
|
95
|
+
if (currentActiveItem !== previousActiveItem) {
|
|
96
|
+
// The player swapped out their active item for something else, so it should be impossible
|
|
97
|
+
// for the discharge callback to fire on this frame.
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const currentCharge = getTotalCharge(player, activeSlot);
|
|
102
|
+
let previousCharge = chargeMap.get(activeSlot);
|
|
103
|
+
if (previousCharge === undefined) {
|
|
104
|
+
previousCharge = currentCharge;
|
|
105
|
+
}
|
|
106
|
+
chargeMap.set(activeSlot, currentCharge);
|
|
107
|
+
|
|
108
|
+
if (this.playerRecentlyCollidedWithBulb(player)) {
|
|
109
|
+
continue;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
if (currentCharge < previousCharge) {
|
|
113
|
+
const collectibleType = player.GetActiveItem(activeSlot);
|
|
114
|
+
this.fire(player, collectibleType, activeSlot);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* If the player collided with a Bulb on either this frame or the last frame, then assume a zap
|
|
121
|
+
* has occurred. (We do not want to fire the discharge callback if this is the case.)
|
|
122
|
+
*/
|
|
123
|
+
private playerRecentlyCollidedWithBulb(player: EntityPlayer) {
|
|
124
|
+
const gameFrameCount = game.GetFrameCount();
|
|
125
|
+
const bulbLastCollisionFrame = mapGetPlayer(
|
|
126
|
+
this.v.room.playersBulbLastCollisionFrame,
|
|
127
|
+
player,
|
|
128
|
+
);
|
|
129
|
+
const collidedOnThisFrame = gameFrameCount === bulbLastCollisionFrame;
|
|
130
|
+
const collidedOnLastFrame = gameFrameCount - 1 === bulbLastCollisionFrame;
|
|
131
|
+
return collidedOnThisFrame || collidedOnLastFrame;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// ModCallback.PRE_NPC_COLLISION (30)
|
|
135
|
+
// EntityType.SUCKER (61)
|
|
136
|
+
private preNPCCollisionSucker = (
|
|
137
|
+
npc: EntityNPC,
|
|
138
|
+
collider: Entity,
|
|
139
|
+
): boolean | undefined => {
|
|
140
|
+
if (npc.Variant === asNumber(SuckerVariant.BULB)) {
|
|
141
|
+
return this.preNPCCollisionBulb(npc, collider);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
return undefined;
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
// ModCallback.PRE_NPC_COLLISION (30)
|
|
148
|
+
// EntityType.SUCKER (61)
|
|
149
|
+
private preNPCCollisionBulb(
|
|
150
|
+
_npc: EntityNPC,
|
|
151
|
+
collider: Entity,
|
|
152
|
+
): boolean | undefined {
|
|
153
|
+
this.checkPlayerCollidedWithBulb(collider);
|
|
154
|
+
return undefined;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* The algorithm for detecting a discharge is checking if the current charge is less than the
|
|
159
|
+
* charge on the previous frame. Thus, when a Bulb zaps a player and drains their charge, this
|
|
160
|
+
* will be a false position, so Bulbs have to be handled.
|
|
161
|
+
*
|
|
162
|
+
* When Bulbs zap a player, they go to `NpcState.STATE_JUMP` for a frame. However, this only
|
|
163
|
+
* happens on the frame after the player is discharged, which is too late to be of any use.
|
|
164
|
+
*
|
|
165
|
+
* Instead, we track the frames that Bulbs collide with players and assume that a collision means
|
|
166
|
+
* a zap has occurred.
|
|
167
|
+
*/
|
|
168
|
+
private checkPlayerCollidedWithBulb(collider: Entity) {
|
|
169
|
+
const player = collider.ToPlayer();
|
|
170
|
+
if (player === undefined) {
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
const gameFrameCount = game.GetFrameCount();
|
|
175
|
+
mapSetPlayer(
|
|
176
|
+
this.v.room.playersBulbLastCollisionFrame,
|
|
177
|
+
player,
|
|
178
|
+
gameFrameCount,
|
|
179
|
+
);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ISCFeature } from "../../enums/ISCFeature";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackItemPickup } from "./validation/CustomCallbackItemPickup";
|
|
4
|
+
|
|
5
|
+
export class PostItemPickup extends CustomCallbackItemPickup<ModCallbackCustom2.POST_ITEM_PICKUP> {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
|
|
9
|
+
this.featuresUsed = [ISCFeature.ITEM_PICKUP_DETECTION];
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackLaser } from "./validation/CustomCallbackLaser";
|
|
4
|
+
|
|
5
|
+
export class PostLaserInitLate extends CustomCallbackLaser<ModCallbackCustom2.POST_LASER_INIT_LATE> {
|
|
6
|
+
public override v = {
|
|
7
|
+
room: {
|
|
8
|
+
firedSet: new Set<PtrHash>(),
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
14
|
+
|
|
15
|
+
this.callbacksUsed = [
|
|
16
|
+
[ModCallback.POST_LASER_UPDATE, [this.postLaserUpdate]], // 51
|
|
17
|
+
];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// ModCallback.POST_LASER_UPDATE (48)
|
|
21
|
+
private postLaserUpdate = (laser: EntityLaser) => {
|
|
22
|
+
const index = GetPtrHash(laser);
|
|
23
|
+
if (!this.v.room.firedSet.has(index)) {
|
|
24
|
+
this.v.room.firedSet.add(index);
|
|
25
|
+
this.fire(laser);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackNPC } from "./validation/CustomCallbackNPC";
|
|
4
|
+
|
|
5
|
+
export class PostNPCInitLate extends CustomCallbackNPC<ModCallbackCustom2.POST_NPC_INIT_LATE> {
|
|
6
|
+
public override v = {
|
|
7
|
+
room: {
|
|
8
|
+
firedSet: new Set<PtrHash>(),
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
14
|
+
|
|
15
|
+
this.callbacksUsed = [
|
|
16
|
+
[ModCallback.POST_NPC_UPDATE, [this.postNPCUpdate]], // 0
|
|
17
|
+
];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// ModCallback.POST_NPC_UPDATE (0)
|
|
21
|
+
private postNPCUpdate = (npc: EntityNPC) => {
|
|
22
|
+
const index = GetPtrHash(npc);
|
|
23
|
+
if (!this.v.room.firedSet.has(index)) {
|
|
24
|
+
this.v.room.firedSet.add(index);
|
|
25
|
+
this.fire(npc);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ModCallback, NpcState } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { DefaultMap } from "../DefaultMap";
|
|
4
|
+
import { CustomCallbackNPC } from "./validation/CustomCallbackNPC";
|
|
5
|
+
|
|
6
|
+
export class PostNPCStateChanged extends CustomCallbackNPC<ModCallbackCustom2.POST_NPC_STATE_CHANGED> {
|
|
7
|
+
public override v = {
|
|
8
|
+
run: {
|
|
9
|
+
stateMap: new DefaultMap<PtrHash, NpcState, [NpcState]>(
|
|
10
|
+
(state) => state, // eslint-disable-line isaacscript/strict-enums
|
|
11
|
+
),
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
constructor() {
|
|
16
|
+
super();
|
|
17
|
+
|
|
18
|
+
this.callbacksUsed = [
|
|
19
|
+
[ModCallback.POST_NPC_UPDATE, [this.postNPCUpdate]], // 0
|
|
20
|
+
];
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// ModCallback.POST_NPC_UPDATE (0)
|
|
24
|
+
private postNPCUpdate = (npc: EntityNPC) => {
|
|
25
|
+
const ptrHash = GetPtrHash(npc);
|
|
26
|
+
const previousState = this.v.run.stateMap.getAndSetDefault(
|
|
27
|
+
ptrHash,
|
|
28
|
+
npc.State,
|
|
29
|
+
);
|
|
30
|
+
const currentState = npc.State;
|
|
31
|
+
this.v.run.stateMap.set(ptrHash, currentState);
|
|
32
|
+
|
|
33
|
+
if (previousState !== currentState) {
|
|
34
|
+
this.fire(npc, previousState, currentState);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { getClosestPlayer } from "../../functions/players";
|
|
4
|
+
import { CustomCallbackPickup } from "./validation/CustomCallbackPickup";
|
|
5
|
+
|
|
6
|
+
export class PostPickupCollect extends CustomCallbackPickup<ModCallbackCustom2.POST_PICKUP_COLLECT> {
|
|
7
|
+
public override v = {
|
|
8
|
+
room: {
|
|
9
|
+
firedSet: new Set<PtrHash>(),
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
constructor() {
|
|
14
|
+
super();
|
|
15
|
+
|
|
16
|
+
this.callbacksUsed = [
|
|
17
|
+
[ModCallback.POST_PICKUP_RENDER, [this.postPickupRender]], // 36
|
|
18
|
+
];
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// ModCallback.POST_PICKUP_RENDER (36)
|
|
22
|
+
private postPickupRender = (pickup: EntityPickup) => {
|
|
23
|
+
const sprite = pickup.GetSprite();
|
|
24
|
+
const animation = sprite.GetAnimation();
|
|
25
|
+
if (animation !== "Collect") {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const index = GetPtrHash(pickup);
|
|
30
|
+
if (!this.v.room.firedSet.has(index)) {
|
|
31
|
+
this.v.room.firedSet.add(index);
|
|
32
|
+
|
|
33
|
+
const player = getClosestPlayer(pickup.Position);
|
|
34
|
+
this.fire(pickup, player);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { game } from "../../core/cachedClasses";
|
|
3
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
4
|
+
import { getRoomVisitedCount } from "../../functions/roomData";
|
|
5
|
+
import { CustomCallbackPickup } from "./validation/CustomCallbackPickup";
|
|
6
|
+
|
|
7
|
+
export class PostPickupInitFirst extends CustomCallbackPickup<ModCallbackCustom2.POST_PICKUP_INIT_FIRST> {
|
|
8
|
+
public override v = {
|
|
9
|
+
room: {
|
|
10
|
+
firedSet: new Set<PtrHash>(),
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
constructor() {
|
|
15
|
+
super();
|
|
16
|
+
|
|
17
|
+
this.callbacksUsed = [
|
|
18
|
+
[ModCallback.POST_PICKUP_INIT, [this.postPickupInit]], // 34
|
|
19
|
+
];
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// ModCallback.POST_PICKUP_INIT (34)
|
|
23
|
+
private postPickupInit = (pickup: EntityPickup) => {
|
|
24
|
+
const room = game.GetRoom();
|
|
25
|
+
const roomFrameCount = room.GetFrameCount();
|
|
26
|
+
const roomVisitedCount = getRoomVisitedCount();
|
|
27
|
+
|
|
28
|
+
// The room visited count is not reset when re-entering a Treasure Room or Boss room in the
|
|
29
|
+
// Ascent.
|
|
30
|
+
if (roomFrameCount > 0 || roomVisitedCount === 0) {
|
|
31
|
+
this.fire(pickup);
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackPickup } from "./validation/CustomCallbackPickup";
|
|
4
|
+
|
|
5
|
+
export class PostPickupInitLate extends CustomCallbackPickup<ModCallbackCustom2.POST_PICKUP_INIT_LATE> {
|
|
6
|
+
public override v = {
|
|
7
|
+
room: {
|
|
8
|
+
firedSet: new Set<PtrHash>(),
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
14
|
+
|
|
15
|
+
this.callbacksUsed = [
|
|
16
|
+
[ModCallback.POST_PICKUP_UPDATE, [this.postPickupUpdate]], // 35
|
|
17
|
+
];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// ModCallback.POST_PICKUP_UPDATE (35)
|
|
21
|
+
private postPickupUpdate = (pickup: EntityPickup) => {
|
|
22
|
+
const index = GetPtrHash(pickup);
|
|
23
|
+
if (!this.v.room.firedSet.has(index)) {
|
|
24
|
+
this.v.room.firedSet.add(index);
|
|
25
|
+
this.fire(pickup);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { DefaultMap } from "../DefaultMap";
|
|
4
|
+
import { CustomCallbackPickup } from "./validation/CustomCallbackPickup";
|
|
5
|
+
|
|
6
|
+
export class PostPickupStateChanged extends CustomCallbackPickup<ModCallbackCustom2.POST_PICKUP_STATE_CHANGED> {
|
|
7
|
+
public override v = {
|
|
8
|
+
run: {
|
|
9
|
+
stateMap: new DefaultMap<PtrHash, int, [int]>((state) => state),
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
constructor() {
|
|
14
|
+
super();
|
|
15
|
+
|
|
16
|
+
this.callbacksUsed = [
|
|
17
|
+
[ModCallback.POST_PICKUP_UPDATE, [this.postPickupUpdate]], // 35
|
|
18
|
+
];
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// ModCallback.POST_PICKUP_UPDATE (35)
|
|
22
|
+
private postPickupUpdate = (pickup: EntityPickup) => {
|
|
23
|
+
const ptrHash = GetPtrHash(pickup);
|
|
24
|
+
const previousState = this.v.run.stateMap.getAndSetDefault(
|
|
25
|
+
ptrHash,
|
|
26
|
+
pickup.State,
|
|
27
|
+
);
|
|
28
|
+
const currentState = pickup.State;
|
|
29
|
+
this.v.run.stateMap.set(ptrHash, currentState);
|
|
30
|
+
|
|
31
|
+
if (previousState !== currentState) {
|
|
32
|
+
this.fire(pickup, previousState, currentState);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { getPits } from "../../functions/gridEntitiesSpecific";
|
|
4
|
+
import { CustomCallbackPit } from "./validation/CustomCallbackPit";
|
|
5
|
+
|
|
6
|
+
export class PostPitUpdate extends CustomCallbackPit<ModCallbackCustom2.POST_PIT_UPDATE> {
|
|
7
|
+
constructor() {
|
|
8
|
+
super();
|
|
9
|
+
|
|
10
|
+
this.callbacksUsed = [
|
|
11
|
+
[ModCallback.POST_UPDATE, [this.postUpdate]], // 1
|
|
12
|
+
];
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// ModCallback.POST_UPDATE (1)
|
|
16
|
+
private postUpdate = (): void => {
|
|
17
|
+
for (const pit of getPits()) {
|
|
18
|
+
this.fire(pit);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { HealthType } from "../../enums/HealthType";
|
|
3
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
4
|
+
import { getEnumValues } from "../../functions/enums";
|
|
5
|
+
import { getPlayerHealthType } from "../../functions/playerHealth";
|
|
6
|
+
import { getPlayerIndex } from "../../functions/playerIndex";
|
|
7
|
+
import { PlayerIndex } from "../../types/PlayerIndex";
|
|
8
|
+
import { DefaultMap } from "../DefaultMap";
|
|
9
|
+
import { CustomCallbackPlayer } from "./validation/CustomCallbackPlayer";
|
|
10
|
+
|
|
11
|
+
export class PostPlayerChangeHealth extends CustomCallbackPlayer<ModCallbackCustom2.POST_PLAYER_CHANGE_HEALTH> {
|
|
12
|
+
public override v = {
|
|
13
|
+
run: {
|
|
14
|
+
playersHealthMap: new DefaultMap<PlayerIndex, Map<HealthType, int>>(
|
|
15
|
+
() => new Map(),
|
|
16
|
+
),
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
constructor() {
|
|
21
|
+
super();
|
|
22
|
+
|
|
23
|
+
this.callbacksUsed = [
|
|
24
|
+
[ModCallback.POST_PEFFECT_UPDATE, [this.postPEffect]], // 4
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// ModCallback.POST_PEFFECT_UPDATE (4)
|
|
29
|
+
private postPEffect = (player: EntityPlayer) => {
|
|
30
|
+
// We call the "getPlayerIndex" function with the "differentiateForgottenAndSoul" argument. If
|
|
31
|
+
// we don't differentiate between The Forgotten and The Soul, the callback will fire every time
|
|
32
|
+
// the player switches between the two.
|
|
33
|
+
const playerIndex = getPlayerIndex(player, true);
|
|
34
|
+
const playerHealthMap =
|
|
35
|
+
this.v.run.playersHealthMap.getAndSetDefault(playerIndex);
|
|
36
|
+
|
|
37
|
+
for (const healthType of getEnumValues(HealthType)) {
|
|
38
|
+
const storedHealthValue = playerHealthMap.get(healthType);
|
|
39
|
+
const currentHealthValue = getPlayerHealthType(player, healthType);
|
|
40
|
+
playerHealthMap.set(healthType, currentHealthValue);
|
|
41
|
+
|
|
42
|
+
if (
|
|
43
|
+
storedHealthValue !== undefined &&
|
|
44
|
+
storedHealthValue !== currentHealthValue
|
|
45
|
+
) {
|
|
46
|
+
const difference = currentHealthValue - storedHealthValue;
|
|
47
|
+
this.fire(
|
|
48
|
+
player,
|
|
49
|
+
healthType,
|
|
50
|
+
difference,
|
|
51
|
+
storedHealthValue,
|
|
52
|
+
currentHealthValue,
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { ModCallback } from "isaac-typescript-definitions";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { StatType } from "../../enums/StatType";
|
|
4
|
+
import { isBitSet128 } from "../../functions/bitSet128";
|
|
5
|
+
import { colorEquals, isColor } from "../../functions/color";
|
|
6
|
+
import { getEnumValues } from "../../functions/enums";
|
|
7
|
+
import { getPlayerIndex } from "../../functions/playerIndex";
|
|
8
|
+
import { getPlayerStat } from "../../functions/playerStats";
|
|
9
|
+
import { isBoolean, isNumber } from "../../functions/types";
|
|
10
|
+
import { isVector, vectorEquals } from "../../functions/vector";
|
|
11
|
+
import { PlayerIndex } from "../../types/PlayerIndex";
|
|
12
|
+
import { PossibleStatType } from "../../types/PossibleStatType";
|
|
13
|
+
import { DefaultMap } from "../DefaultMap";
|
|
14
|
+
import { CustomCallbackPlayer } from "./validation/CustomCallbackPlayer";
|
|
15
|
+
|
|
16
|
+
export class PostPlayerChangeStat extends CustomCallbackPlayer<ModCallbackCustom2.POST_PLAYER_CHANGE_STAT> {
|
|
17
|
+
public override v = {
|
|
18
|
+
run: {
|
|
19
|
+
playersStatMap: new DefaultMap<
|
|
20
|
+
PlayerIndex,
|
|
21
|
+
Map<StatType, PossibleStatType>
|
|
22
|
+
>(() => new Map()),
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
constructor() {
|
|
27
|
+
super();
|
|
28
|
+
|
|
29
|
+
this.callbacksUsed = [
|
|
30
|
+
[ModCallback.POST_PEFFECT_UPDATE, [this.postPEffect]], // 4
|
|
31
|
+
];
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// ModCallback.POST_PEFFECT_UPDATE (4)
|
|
35
|
+
private postPEffect = (player: EntityPlayer) => {
|
|
36
|
+
// We call the "getPlayerIndex" function with the "differentiateForgottenAndSoul" argument. If
|
|
37
|
+
// we don't differentiate between The Forgotten and The Soul, the callback will fire every time
|
|
38
|
+
// the player switches between the two.
|
|
39
|
+
const playerIndex = getPlayerIndex(player, true);
|
|
40
|
+
const playerStatMap =
|
|
41
|
+
this.v.run.playersStatMap.getAndSetDefault(playerIndex);
|
|
42
|
+
|
|
43
|
+
for (const statType of getEnumValues(StatType)) {
|
|
44
|
+
const storedStatValue = playerStatMap.get(statType);
|
|
45
|
+
const currentStatValue = getPlayerStat(player, statType);
|
|
46
|
+
playerStatMap.set(statType, currentStatValue);
|
|
47
|
+
|
|
48
|
+
if (storedStatValue === undefined) {
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
if (!statEquals(storedStatValue, currentStatValue)) {
|
|
53
|
+
const isNumberStat =
|
|
54
|
+
isNumber(storedStatValue) && isNumber(currentStatValue);
|
|
55
|
+
const difference = isNumberStat
|
|
56
|
+
? currentStatValue - storedStatValue
|
|
57
|
+
: 0;
|
|
58
|
+
this.fire(
|
|
59
|
+
player,
|
|
60
|
+
statType,
|
|
61
|
+
difference,
|
|
62
|
+
storedStatValue,
|
|
63
|
+
currentStatValue,
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function statEquals(
|
|
71
|
+
oldValue: PossibleStatType,
|
|
72
|
+
newValue: PossibleStatType,
|
|
73
|
+
): boolean {
|
|
74
|
+
const isNumberStat = isNumber(oldValue) && isNumber(newValue);
|
|
75
|
+
if (isNumberStat) {
|
|
76
|
+
return oldValue === newValue;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const isBooleanStat = isBoolean(oldValue) && isBoolean(newValue);
|
|
80
|
+
if (isBooleanStat) {
|
|
81
|
+
return oldValue === newValue;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
const isBitSet128Stat = isBitSet128(oldValue) && isBitSet128(newValue);
|
|
85
|
+
if (isBitSet128Stat) {
|
|
86
|
+
return oldValue === newValue; // The class has the "__eq" meta-method.
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const isColorStat = isColor(oldValue) && isColor(newValue);
|
|
90
|
+
if (isColorStat) {
|
|
91
|
+
return colorEquals(oldValue, newValue);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
const isVectorStat = isVector(oldValue) && isVector(newValue);
|
|
95
|
+
if (isVectorStat) {
|
|
96
|
+
return vectorEquals(oldValue, newValue);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
error(
|
|
100
|
+
'Failed to determine the type of a stat in the "POST_PLAYER_CHANGE_STAT" callback.',
|
|
101
|
+
);
|
|
102
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ModCallback, PlayerType } from "isaac-typescript-definitions";
|
|
2
|
+
import { postPlayerChangeTypeFire } from "../../callbacks/subscriptions/postPlayerChangeType";
|
|
3
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
4
|
+
import {
|
|
5
|
+
defaultMapGetPlayer,
|
|
6
|
+
mapSetPlayer,
|
|
7
|
+
} from "../../functions/playerDataStructures";
|
|
8
|
+
import { PlayerIndex } from "../../types/PlayerIndex";
|
|
9
|
+
import { DefaultMap } from "../DefaultMap";
|
|
10
|
+
import { CustomCallbackPlayer } from "./validation/CustomCallbackPlayer";
|
|
11
|
+
|
|
12
|
+
export class PostPlayerChangeType extends CustomCallbackPlayer<ModCallbackCustom2.POST_PLAYER_CHANGE_TYPE> {
|
|
13
|
+
public override v = {
|
|
14
|
+
run: {
|
|
15
|
+
playersCharacterMap: new DefaultMap<
|
|
16
|
+
PlayerIndex,
|
|
17
|
+
PlayerType,
|
|
18
|
+
[character: PlayerType]
|
|
19
|
+
>((character: PlayerType) => character), // eslint-disable-line isaacscript/strict-enums
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
|
|
26
|
+
this.callbacksUsed = [
|
|
27
|
+
[ModCallback.POST_PEFFECT_UPDATE, [this.postPEffect]], // 4
|
|
28
|
+
];
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// ModCallback.POST_PEFFECT_UPDATE (4)
|
|
32
|
+
private postPEffect = (player: EntityPlayer) => {
|
|
33
|
+
const character = player.GetPlayerType();
|
|
34
|
+
const storedCharacter = defaultMapGetPlayer(
|
|
35
|
+
this.v.run.playersCharacterMap,
|
|
36
|
+
player,
|
|
37
|
+
character,
|
|
38
|
+
);
|
|
39
|
+
if (character !== storedCharacter) {
|
|
40
|
+
mapSetPlayer(this.v.run.playersCharacterMap, player, character);
|
|
41
|
+
postPlayerChangeTypeFire(player, storedCharacter, character);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ISCFeature } from "../../enums/ISCFeature";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackCollectibleType } from "./validation/CustomCallbackCollectibleType";
|
|
4
|
+
|
|
5
|
+
export class PostPlayerCollectibleAdded extends CustomCallbackCollectibleType<ModCallbackCustom2.POST_PLAYER_COLLECTIBLE_ADDED> {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
|
|
9
|
+
this.featuresUsed = [ISCFeature.PLAYER_COLLECTIBLE_DETECTION];
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ISCFeature } from "../../enums/ISCFeature";
|
|
2
|
+
import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
|
|
3
|
+
import { CustomCallbackCollectibleType } from "./validation/CustomCallbackCollectibleType";
|
|
4
|
+
|
|
5
|
+
export class PostPlayerCollectibleRemoved extends CustomCallbackCollectibleType<ModCallbackCustom2.POST_PLAYER_COLLECTIBLE_REMOVED> {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
|
|
9
|
+
this.featuresUsed = [ISCFeature.PLAYER_COLLECTIBLE_DETECTION];
|
|
10
|
+
}
|
|
11
|
+
}
|