dash_import.html 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <div class="modal-body">
  2. <div class="modal-header">
  3. <h2 class="modal-header-title">
  4. <i class="fa fa-upload"></i>
  5. <span class="p-l-1">Import Dashboard</span>
  6. </h2>
  7. <a class="modal-header-close" ng-click="dismiss();">
  8. <i class="fa fa-remove"></i>
  9. </a>
  10. </div>
  11. <div class="modal-content" ng-cloak>
  12. <div ng-if="ctrl.step === 1">
  13. <form class="gf-form-group">
  14. <dash-upload on-upload="ctrl.onUpload(dash)"></dash-upload>
  15. </form>
  16. <h5 class="section-heading">Grafana.net Dashboard</h5>
  17. <div class="gf-form-group">
  18. <div class="gf-form">
  19. <input type="text" class="gf-form-input" ng-ctrl="ctrl.grafanaNetUrl" placeholder="Paste Grafana.net dashboard url or id" ng-change="ctrl.checkGnetDashboard()"></textarea>
  20. </div>
  21. <div class="gf-form" ng-if="ctrl.gnetError">
  22. <label class="gf-form-label text-warning">
  23. <i class="fa fa-warning"></i>
  24. {{ctrl.gnetError}}
  25. </label>
  26. </div>
  27. </div>
  28. <h5 class="section-heading">Or paste JSON</h5>
  29. <div class="gf-form-group">
  30. <div class="gf-form">
  31. <textarea rows="7" data-share-panel-url="" class="gf-form-input" ng-ctrl="ctrl.jsonText"></textarea>
  32. </div>
  33. <button type="button" class="btn btn-secondary" ng-click="ctrl.loadJsonText()">
  34. <i class="fa fa-paste"></i>
  35. Load
  36. </button>
  37. <span ng-if="ctrl.parseError" class="text-error p-l-1">
  38. <i class="fa fa-warning"></i>
  39. {{ctrl.parseError}}
  40. </span>
  41. </div>
  42. </div>
  43. <div ng-if="ctrl.step === 2">
  44. <h3 class="section-heading">
  45. Options
  46. </h3>
  47. <div class="gf-form-group">
  48. <div class="gf-form-inline">
  49. <div class="gf-form gf-form--grow">
  50. <label class="gf-form-label width-15">Title</label>
  51. <input type="text" class="gf-form-input" ng-model="ctrl.dash.title" give-focus="true" ng-change="ctrl.titleChanged()" ng-class="{'validation-error': ctrl.nameExists}">
  52. <label class="gf-form-label text-success" ng-if="!ctrl.nameExists">
  53. <i class="fa fa-check"></i>
  54. </label>
  55. </div>
  56. </div>
  57. <div class="gf-form-inline" ng-if="ctrl.nameExists">
  58. <div class="gf-form offset-width-15 gf-form--grow">
  59. <label class="gf-form-label text-warning gf-form-label--grow">
  60. <i class="fa fa-warning"></i>
  61. A Dashboard with the same name already exists
  62. </label>
  63. </div>
  64. </div>
  65. <div ng-repeat="input in ctrl.inputs">
  66. <div class="gf-form">
  67. <label class="gf-form-label width-15">{{input.label}}</label>
  68. <div class="gf-form-select-wrapper" style="width: 100%">
  69. <select class="gf-form-input" ng-model="input.value" ng-options="v.value as v.text for v in input.options" ng-change="ctrl.inputValueChanged()"></select>
  70. </div>
  71. <label class="gf-form-label text-success" ng-show="input.value">
  72. <i class="fa fa-check"></i>
  73. </label>
  74. </div>
  75. <div class="gf-form offset-width-15 gf-form--grow">
  76. <label class="gf-form-label gf-form-label--grow" ng-show="input.info">
  77. <i class="fa fa-info-circle"></i>
  78. {{input.info}}
  79. </label>
  80. <label class="gf-form-label gf-form-label--grow" ng-show="input.error">
  81. <i class="fa fa-info-circle"></i>
  82. {{input.info}}
  83. </label>
  84. </div>
  85. </div>
  86. </div>
  87. <div class="gf-form-button-row">
  88. <button type="button" class="btn gf-form-btn width-10" ng-click="ctrl.saveDashboard()" ng-class="{'btn-danger': ctrl.nameExists, 'btn-success': !ctrl.nameExists}" ng-disabled="!ctrl.inputsValid">
  89. <i class="fa fa-save"></i> Save &amp; Open
  90. </button>
  91. <a class="btn btn-link" ng-click="dismiss()">Cancel</a>
  92. </div>
  93. </div>
  94. </div>
  95. </div>