axsh/wakame-vdc

View on GitHub
frontend/dcmgr_gui/public/javascripts/dcmgr_gui/sshkeypair_panel.js

Summary

Maintainability
F
5 days
Test Coverage
DcmgrGUI.prototype.sshKeyPairPanel = function(){
  var total = 0;
  var maxrow = 10;
  var page = 1;
  var list_request = {
    "url" : DcmgrGUI.Util.getPagePath('/keypairs/list/',page),
    "data" : DcmgrGUI.Util.getPagenateData(page,maxrow)
  };

  DcmgrGUI.List.prototype.getEmptyData = function(){
    return [{
    }]
  }

  DcmgrGUI.Detail.prototype.getEmptyData = function(){
    return {
      "create_at" : "-",
      "update_at":''
    }
  }

  var create_button_name = $.i18n.prop('create_button');
  var delete_button_name = $.i18n.prop('delete_button');
  var update_button_name = $.i18n.prop('update_button');
  var close_button_name = $.i18n.prop('close_button');

  var c_pagenate = new DcmgrGUI.Pagenate({
    row:maxrow,
    total:total
  });

  var c_list = new DcmgrGUI.List({
    element_id:'#display_ssh_keypairs',
    template_id:'#sshKeyPairsListTemplate',
    maxrow:maxrow,
    page:page
  });

  c_list.setDetailTemplate({
    template_id:'#sshKeypairsDetailTemplate',
    detail_path:'/keypairs/show/'
  });

  c_list.element.bind('dcmgrGUI.contentChange', function(event,params){
    var ssh_key_pair = params.data.ssh_key_pair;
    c_pagenate.changeTotal(ssh_key_pair.total);
    c_list.setData(ssh_key_pair.results);
    c_list.singleCheckList(c_list.detail_template);

    var edit_ssh_keypair_buttons = {};
    edit_ssh_keypair_buttons[close_button_name] = function() { $(this).dialog("close"); };
    edit_ssh_keypair_buttons[update_button_name] = function() {
      var uuid = $(this).find('#ssh_keypair_id').val();
      var display_name = $(this).find('#ssh_keypair_display_name').val();
      var description = $(this).find('#ssh_keypair_description').val();
      var data = 'display_name=' + encodeURIComponent(display_name)
               + '&description=' + encodeURIComponent(description)
      var request = new DcmgrGUI.Request
      request.put({
    "url": '/keypairs/edit_ssh_keypair/'+uuid+'.json',
    "data": data,
    success: function(json,status){
      bt_refresh.element.trigger('dcmgrGUI.refresh');
    }
      });

      $(this).dialog("close");
    };

    var bt_edit_ssh_keypair = new DcmgrGUI.Dialog({
      target:'.edit_ssh_keypair',
      width:500,
      height:230,
      title:$.i18n.prop('edit_ssh_keypair_header'),
      path:'/edit_ssh_keypair',
      callback: function(){
        var params = { 'button': bt_edit_ssh_keypair, 'element_id': 1 };
        $(this).find('#ssh_keypair_display_name').bind('paste', params, DcmgrGUI.Util.availableTextField);
        $(this).find('#ssh_keypair_display_name').bind('cut', params, DcmgrGUI.Util.availableTextField);
        $(this).find('#ssh_keypair_display_name').bind('keyup', params, DcmgrGUI.Util.availableTextField);
      },
      button: edit_ssh_keypair_buttons
    });

    bt_edit_ssh_keypair.target.bind('click', function(){
      var uuid = $(this).attr('id').replace(/edit_(ssh-[a-z0-9]+)/,'$1');
      if( uuid ){
        bt_edit_ssh_keypair.open({"ids":[uuid]});
      }
      c_list.checkRadioButton(uuid);
    });

    $(bt_edit_ssh_keypair.target).button({ disabled: false });
  });

  var bt_refresh  = new DcmgrGUI.Refresh();

  bt_refresh.element.bind('dcmgrGUI.refresh', function(){
    //Update list element
    c_list.page = c_pagenate.current_page;
    list_request.url = DcmgrGUI.Util.getPagePath('/keypairs/list/', c_list.page);
    list_request.data = DcmgrGUI.Util.getPagenateData(c_pagenate.start,c_pagenate.row);
    c_list.element.trigger('dcmgrGUI.updateList', {request:list_request})

    var check_id = c_list.currentChecked();
    //remove detail element
    $($('#detail').find('#'+check_id)).remove();
    $(bt_delete_ssh_keypair.target).button({ disabled: true });
  });

  c_pagenate.element.bind('dcmgrGUI.updatePagenate', function(){
    c_list.clearCheckedList();
    $('#detail').html('');
    bt_refresh.element.trigger('dcmgrGUI.refresh');
  });

  var create_ssh_keypair_buttons = {};
  create_ssh_keypair_buttons[close_button_name] = function() { $(this).dialog("close"); };
  create_ssh_keypair_buttons[create_button_name] = function() {
    var display_name = $(this).find('#ssh_keypair_display_name').val();
    var description = $(this).find('#ssh_keypair_description').val();
    var public_key = $(this).find('#ssh_public_key').val();

    if(jQuery.browser.version == '8.0' && $.browser.msie) {
      display_name = encodeURIComponent(display_name);
      description = encodeURIComponent(description)
    }

    if(_.isEmpty(public_key)){
      var html = '<form accept-charset="UTF-8" id="prk_download" action="/keypairs/create_ssh_keypair" method="post">'
          +'<input type="hidden" name="display_name" value="'+display_name+ '">'
          +'<input type="hidden" name="description" value="'+description+ '">'
          +'</form>'
      var iframe = $(this).find('iframe:first').contents();
      iframe.find('body').append(html);
      iframe.find("#prk_download").submit();
    } else {
      var request = new DcmgrGUI.Request
      var data = "display_name=" + encodeURIComponent(display_name) +
                 "&description=" + encodeURIComponent(description) +
                 "&public_key=" + encodeURIComponent(public_key);

      request.post({
        "url": '/keypairs/create_ssh_keypair.json',
        "data": data,
        success: function(json,status){
          //nop
        }
      });
    }

    var request = new DcmgrGUI.Request
    request.get({
      "url": '/keypairs/all.json',
      "data": "",
      success: function(json,status){
    bt_refresh.element.trigger('dcmgrGUI.refresh');
      }
    });

    $(this).dialog("close");
  }

  var bt_create_ssh_keypair = new DcmgrGUI.Dialog({
    target:'.create_ssh_keypair',
    width:500,
    height:420,
    title:$.i18n.prop('create_ssh_keypair_header'),
    path:'/create_ssh_keypair',
    callback: function(){
      var html = '<iframe src="javascript:false" name="hiddenIframe" style="display:none"></iframe>';
      $(this).find('#create_and_edit_ssh_keypair_dialog').append(html);

      var params = { 'button': bt_create_ssh_keypair, 'element_id': 1 };
      $(this).find('#ssh_keypair_display_name').bind('paste', params, DcmgrGUI.Util.availableTextField);
      $(this).find('#ssh_keypair_display_name').bind('cut', params, DcmgrGUI.Util.availableTextField);
      $(this).find('#ssh_keypair_display_name').bind('keyup', params, DcmgrGUI.Util.availableTextField);
    },
    button: create_ssh_keypair_buttons
  });

  bt_create_ssh_keypair.target.bind('click', function(){
    bt_create_ssh_keypair.open();
    bt_create_ssh_keypair.disabledButton(1,true);
  });

  var delete_ssh_keypair_buttons = {};
  delete_ssh_keypair_buttons[close_button_name] = function() { $(this).dialog("close"); };
  delete_ssh_keypair_buttons[delete_button_name] = function() {
    var ssh_keypair_id = $(this).find('#ssh_keypair_id').val();

    var request = new DcmgrGUI.Request;
    request.del({
      "url": '/keypairs/'+ ssh_keypair_id +'.json',
      success: function(json, status){
        bt_refresh.element.trigger('dcmgrGUI.refresh');
      }
    });

    $(this).dialog("close");
  }

  var bt_delete_ssh_keypair = new DcmgrGUI.Dialog({
    target: '.delete_ssh_keypair',
    width: 400,
    height: 230,
    title: $.i18n.prop('delete_ssh_keypair_header'),
    path: '/delete_ssh_keypair',
    button: delete_ssh_keypair_buttons
  });

  dcmgrGUI.notification.subscribe('checked_radio', bt_delete_ssh_keypair, 'enableDialogButton');
  dcmgrGUI.notification.subscribe('change_pagenate', bt_delete_ssh_keypair, 'disableDialogButton');

  $(bt_create_ssh_keypair.target).button({ disabled: false });
  $(bt_delete_ssh_keypair.target).button({ disabled: true });
  $(bt_refresh.target).button({ disabled: false });

  bt_delete_ssh_keypair.target.bind('click', function() {
    var id = c_list.currentChecked();
    if( id ){
      bt_delete_ssh_keypair.open({"ids":[id]});
    }
    return false;
  });

  c_list.setData(null);
  c_list.update(list_request,true);
}