package funkin.ui;

import funkin.data.notestyle.NoteStyleRegistry;
import flixel.addons.effects.chainable.FlxEffectSprite;
import flixel.addons.effects.chainable.FlxOutlineEffect;
import flixel.group.FlxGroup.FlxTypedGroup;
import flixel.util.FlxColor;
import funkin.ui.OptionsState.Page;
import funkin.play.notes.NoteSprite;

class ColorsMenu extends Page
{
  var curSelected:Int = 0;

  var grpNotes:FlxTypedGroup<NoteSprite>;

  public function new()
  {
    super();

    grpNotes = new FlxTypedGroup<NoteSprite>();
    add(grpNotes);

    for (i in 0...4)
    {
      var note:NoteSprite = new NoteSprite(NoteStyleRegistry.instance.fetchDefault(), 0, i);

      note.x = (100 * i) + i;
      note.screenCenter(Y);

      var _effectSpr:FlxEffectSprite = new FlxEffectSprite(note, [new FlxOutlineEffect(FlxOutlineMode.FAST, FlxColor.WHITE, 4, 1)]);
      add(_effectSpr);
      _effectSpr.y = 0;
      _effectSpr.x = i * 130;
      _effectSpr.scale.x = _effectSpr.scale.y = 0.7;
      // _effectSpr.setGraphicSize();
      _effectSpr.height = note.height;
      _effectSpr.width = note.width;

      // _effectSpr.updateHitbox();

      grpNotes.add(note);
    }
  }

  override function update(elapsed:Float)
  {
    if (controls.UI_RIGHT_P) curSelected += 1;
    if (controls.UI_LEFT_P) curSelected -= 1;

    if (curSelected < 0) curSelected = grpNotes.members.length - 1;
    if (curSelected >= grpNotes.members.length) curSelected = 0;

    if (controls.UI_UP)
    {
      // grpNotes.members[curSelected].colorSwap.update(elapsed * 0.3);
      // Note.arrowColors[curSelected] += elapsed * 0.3;
    }

    if (controls.UI_DOWN)
    {
      // grpNotes.members[curSelected].colorSwap.update(-elapsed * 0.3);
      // Note.arrowColors[curSelected] += -elapsed * 0.3;
    }

    super.update(elapsed);
  }
}