48 lines
1.0 KiB
Ruby
48 lines
1.0 KiB
Ruby
|
|
require "source_view"
|
|
require "instruction_view"
|
|
|
|
class BlockView
|
|
|
|
include React::Component
|
|
required_param :interpreter
|
|
|
|
define_state :block => []
|
|
define_state :block_name => ""
|
|
|
|
before_mount do
|
|
interpreter.register_event(:instruction_changed, self)
|
|
update_block
|
|
end
|
|
|
|
def update_block
|
|
block_name! interpreter.block.name
|
|
codes = interpreter.block.codes.dup
|
|
codes.shift while( codes.index(interpreter.instruction) > 1 )
|
|
codes.pop while(codes.length > 4)
|
|
block! codes
|
|
end
|
|
|
|
def instruction_changed
|
|
update_block
|
|
end
|
|
|
|
def render
|
|
return unless block
|
|
div.row do
|
|
div.col_md_5 do
|
|
SourceView :source => interpreter.instruction.source
|
|
end
|
|
div.col_md_5 do
|
|
h6 { "Block: #{block_name}"}
|
|
block.each do |code|
|
|
InstructionView :interpreter => interpreter , :instruction => code
|
|
end
|
|
end
|
|
div.col_md_2 do
|
|
button.btn.btn_default { "next" }.on(:click) { interpreter.tick }
|
|
end
|
|
end
|
|
end
|
|
end
|