ds_edit.html 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <navbar title="Data Sources" title-url="datasources" icon="icon-gf icon-gf-datasources">
  2. </navbar>
  3. <div class="page-container">
  4. <div class="page-header">
  5. <h1 ng-show="ctrl.isNew">Add data source</h1>
  6. <h1 ng-hide="ctrl.isNew">Edit data source</h1>
  7. <div class="page-header-tabs" ng-show="ctrl.hasDashboards">
  8. <ul class="gf-tabs">
  9. <li class="gf-tabs-item">
  10. <a class="gf-tabs-link" ng-click="ctrl.tabIndex = 0" ng-class="{active: ctrl.tabIndex === 0}">
  11. Config
  12. </a>
  13. </li>
  14. <li class="gf-tabs-item">
  15. <a class="gf-tabs-link" ng-click="ctrl.tabIndex = 1" ng-class="{active: ctrl.tabIndex === 1}">
  16. Dashboards
  17. </a>
  18. </li>
  19. </ul>
  20. </div>
  21. </div>
  22. <div ng-if="ctrl.tabIndex === 0" class="tab-content">
  23. <form name="ctrl.editForm">
  24. <div class="gf-form-group">
  25. <div class="gf-form-inline">
  26. <div class="gf-form">
  27. <span class="gf-form-label width-7">Name</span>
  28. <input class="gf-form-input max-width-21" type="text" ng-model="ctrl.current.name" placeholder="My data source name" required>
  29. </div>
  30. <info-popover offset="0px -130px">
  31. The name is used when you select the data source in panels.
  32. The <code>Default</code> data source is preselected in new
  33. panels.
  34. </info-popover>
  35. <gf-form-switch class="gf-form" label="Default" checked="ctrl.current.isDefault" switch-class="max-width-6"></gf-form-switch>
  36. </div>
  37. <div class="gf-form">
  38. <span class="gf-form-label width-7">Type</span>
  39. <div class="gf-form-select-wrapper max-width-21">
  40. <select class="gf-form-input" ng-model="ctrl.current.type" ng-options="v.id as v.name for v in ctrl.types" ng-change="ctrl.typeChanged()"></select>
  41. </div>
  42. </div>
  43. </div>
  44. <rebuild-on-change property="ctrl.datasourceMeta.id">
  45. <plugin-component type="datasource-config-ctrl">
  46. </plugin-component>
  47. </rebuild-on-change>
  48. <div ng-if="ctrl.testing" style="margin-top: 25px">
  49. <h5 ng-show="!ctrl.testing.done">Testing.... <i class="fa fa-spiner fa-spin"></i></h5>
  50. <h5 ng-show="ctrl.testing.done">Test results</h5>
  51. <div class="alert-{{ctrl.testing.status}} alert">
  52. <div class="alert-title">{{ctrl.testing.title}}</div>
  53. <div ng-bind='ctrl.testing.message'></div>
  54. </div>
  55. </div>
  56. <div class="gf-form-button-row">
  57. <button type="submit" class="btn btn-success" ng-show="ctrl.isNew" ng-click="ctrl.saveChanges()">Add</button>
  58. <button type="submit" class="btn btn-success" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges()">Save</button>
  59. <button type="submit" class="btn btn-secondary" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges(true)">
  60. Test Connection
  61. </button>
  62. <button type="submit" class="btn btn-danger" ng-show="!ctrl.isNew" ng-click="ctrl.delete()">
  63. Delete
  64. </button>
  65. <a class="btn btn-link" href="datasources">Cancel</a>
  66. </div>
  67. </form>
  68. </div>
  69. <div ng-if="ctrl.tabIndex === 1" class="tab-content">
  70. <dashboard-import-list plugin="ctrl.datasourceMeta" datasource="ctrl.current"></dashboard-import-list>
  71. </div>
  72. </div>