+++ /dev/null
-using Content.Shared.Smoking;
-using JetBrains.Annotations;
-using Robust.Client.GameObjects;
-using Robust.Shared.GameObjects;
-using Robust.Shared.IoC;
-using Robust.Shared.Serialization;
-using Robust.Shared.Serialization.Manager.Attributes;
-
-namespace Content.Client.Smoking
-{
- [UsedImplicitly]
- public sealed class BurnStateVisualizer : AppearanceVisualizer, ISerializationHooks
- {
- [Dependency] private readonly IEntityManager _entMan = default!;
-
- [DataField("burntIcon")]
- private string _burntIcon = "burnt-icon";
- [DataField("litIcon")]
- private string _litIcon = "lit-icon";
- [DataField("unlitIcon")]
- private string _unlitIcon = "icon";
-
- void ISerializationHooks.AfterDeserialization()
- {
- IoCManager.InjectDependencies(this);
- }
-
- [Obsolete("Subscribe to AppearanceChangeEvent instead.")]
- public override void OnChangeData(AppearanceComponent component)
- {
- base.OnChangeData(component);
-
- if (!_entMan.TryGetComponent(component.Owner, out SpriteComponent? sprite))
- return;
-
- if (!component.TryGetData<SmokableState>(SmokingVisuals.Smoking, out var burnState))
- return;
-
- var state = burnState switch
- {
- SmokableState.Lit => _litIcon,
- SmokableState.Burnt => _burntIcon,
- _ => _unlitIcon
- };
-
- sprite.LayerSetState(0, state);
- }
- }
-}
--- /dev/null
+using Robust.Client.GameObjects;
+using Content.Shared.Smoking;
+
+namespace Content.Client.Smoking;
+
+public sealed class BurnStateVisualizerSystem : VisualizerSystem<BurnStateVisualsComponent>
+{
+ protected override void OnAppearanceChange(EntityUid uid, BurnStateVisualsComponent component, ref AppearanceChangeEvent args)
+ {
+ if (args.Sprite == null)
+ return;
+ if (!args.AppearanceData.TryGetValue(SmokingVisuals.Smoking, out var burnState))
+ return;
+
+ var state = burnState switch
+ {
+ SmokableState.Lit => component.LitIcon,
+ SmokableState.Burnt => component.BurntIcon,
+ _ => component.UnlitIcon
+ };
+
+ args.Sprite.LayerSetState(0, state);
+ }
+}
+
--- /dev/null
+namespace Content.Client.Smoking;
+
+[RegisterComponent]
+public sealed class BurnStateVisualsComponent : Component
+{
+ [DataField("burntIcon")]
+ public string BurntIcon = "burnt-icon";
+ [DataField("litIcon")]
+ public string LitIcon = "lit-icon";
+ [DataField("unlitIcon")]
+ public string UnlitIcon = "icon";
+}
+
-using Robust.Shared.Serialization;
+using Robust.Shared.Serialization;
namespace Content.Shared.Smoking
{
size: 3
sprite: Objects/Consumable/Smokeables/Pipes/pipe.rsi
- type: Appearance
- visuals:
- - type: BurnStateVisualizer
- unlitIcon: unlit-icon
+ - type: BurnStateVisuals
+ unlitIcon: unlit-icon
- type: entity
id: SmokingPipeFilledTobacco
bowl_slot: !type:ContainerSlot
- type: ItemSlots
- type: SmokingPipe
- bowl_slot:
+ bowl_slot:
name: Bowl
startingItem: GroundTobacco
whitelist:
tags:
- Smokable
- insertSound:
+ insertSound:
path: /Audio/Weapons/Guns/Empty/empty.ogg
- ejectSound:
+ ejectSound:
path: /Audio/Weapons/Guns/Empty/empty.ogg
- type: entity
bowl_slot: !type:ContainerSlot
- type: ItemSlots
- type: SmokingPipe
- bowl_slot:
+ bowl_slot:
name: Bowl
startingItem: GroundCannabis
whitelist:
tags:
- Smokable
- insertSound:
+ insertSound:
+ path: /Audio/Weapons/Guns/Empty/empty.ogg
+ ejectSound:
path: /Audio/Weapons/Guns/Empty/empty.ogg
- ejectSound:
- path: /Audio/Weapons/Guns/Empty/empty.ogg
\ No newline at end of file
- type: Sprite
netsync: false
- type: Appearance
- visuals:
- - type: BurnStateVisualizer
+ - type: BurnStateVisuals
- type: Tag
tags:
- Trash
-- type: entity
+- type: entity
id: SmallboxItem
parent: BaseStorageItem
abstract: true
radius: 1.1
color: darkorange
- type: Appearance
- visuals:
- - type: BurnStateVisualizer
- unlitIcon: match_unlit
- litIcon: match_lit
- burntIcon: match_burnt
+ - type: BurnStateVisuals
+ unlitIcon: match_unlit
+ litIcon: match_lit
+ burntIcon: match_burnt
- type: entity
parent: Matchstick