$(function() {
    // TODO: someone should fix all of this...
    // $("a[rel*=leanModal]").leanModal(); //TODO: Make this work with the new modal library. Try and integrate this with the "slices"

    $('body').append('\
    <div id="circuit_editor_modal" class="modal hide fade"> \
      <div class="modal-body"> \
        <input class="schematic" height="300" width="500" id="schematic_editor" name="schematic" type="hidden" value=""/> \
      </div> \
      <div class="modal-footer"> \
        <button type="button" id="circuit_save_btn" class="btn btn-primary" data-dismiss="modal"> \
          Save circuit \
        </button> \
      </div> \
    </div>');

    // This is the editor that pops up as a modal
    var editorCircuit = $('#schematic_editor').get(0);
    // This is the circuit that they last clicked. The one being edited.
    var editingCircuit = null;
    // Notice we use live, because new circuits can be inserted
    $('.schematic_open').live('click', function() {
      // Find the new editingCircuit. Transfer its contents to the editorCircuit
        editingCircuit = $(this).children('input.schematic').get(0);

        editingCircuit.schematic.update_value();
        var circuit_so_far = $(editingCircuit).val();

        var n = editorCircuit.schematic.components.length;
        for (var i = 0; i < n; i++)
            editorCircuit.schematic.components[n - 1 - i].remove();

        editorCircuit.schematic.load_schematic(circuit_so_far, '');
        editorCircuit.schematic.zoomall();
    });

    $('#circuit_save_btn').click(function() {
      // Take the circuit from the editor and put it back into editingCircuit
        editorCircuit.schematic.update_value();
        var saving_circuit = $(editorCircuit).val();

        var n = editingCircuit.schematic.components.length;
        for (var i = 0; i < n; i++)
            editingCircuit.schematic.components[n - 1 - i].remove();

        editingCircuit.schematic.load_schematic(saving_circuit, '');
        editingCircuit.schematic.zoomall();
    });
});