|
@@ -22,6 +22,8 @@ const template = `
|
|
|
<div class="gf-form">
|
|
<div class="gf-form">
|
|
|
<folder-picker initial-folder-id="ctrl.folderId"
|
|
<folder-picker initial-folder-id="ctrl.folderId"
|
|
|
on-change="ctrl.onFolderChange($folder)"
|
|
on-change="ctrl.onFolderChange($folder)"
|
|
|
|
|
+ enter-folder-creation="ctrl.onEnterFolderCreation()"
|
|
|
|
|
+ exit-folder-creation="ctrl.onExitFolderCreation()"
|
|
|
enable-create-new="true"
|
|
enable-create-new="true"
|
|
|
label-class="width-7">
|
|
label-class="width-7">
|
|
|
</folder-picker>
|
|
</folder-picker>
|
|
@@ -29,7 +31,7 @@ const template = `
|
|
|
</div>
|
|
</div>
|
|
|
|
|
|
|
|
<div class="gf-form-button-row text-center">
|
|
<div class="gf-form-button-row text-center">
|
|
|
- <button type="submit" class="btn btn-success" ng-click="ctrl.save()">Save</button>
|
|
|
|
|
|
|
+ <button type="submit" class="btn btn-success" ng-click="ctrl.save()" ng-disabled="!ctrl.isValidFolderSelection">Save</button>
|
|
|
<a class="btn-text" ng-click="ctrl.dismiss();">Cancel</a>
|
|
<a class="btn-text" ng-click="ctrl.dismiss();">Cancel</a>
|
|
|
</div>
|
|
</div>
|
|
|
</form>
|
|
</form>
|
|
@@ -40,6 +42,7 @@ export class SaveDashboardAsModalCtrl {
|
|
|
clone: any;
|
|
clone: any;
|
|
|
folderId: any;
|
|
folderId: any;
|
|
|
dismiss: () => void;
|
|
dismiss: () => void;
|
|
|
|
|
+ isValidFolderSelection = true;
|
|
|
|
|
|
|
|
/** @ngInject */
|
|
/** @ngInject */
|
|
|
constructor(private dashboardSrv) {
|
|
constructor(private dashboardSrv) {
|
|
@@ -79,6 +82,14 @@ export class SaveDashboardAsModalCtrl {
|
|
|
onFolderChange(folder) {
|
|
onFolderChange(folder) {
|
|
|
this.folderId = folder.id;
|
|
this.folderId = folder.id;
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+ onEnterFolderCreation() {
|
|
|
|
|
+ this.isValidFolderSelection = false;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ onExitFolderCreation() {
|
|
|
|
|
+ this.isValidFolderSelection = true;
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
export function saveDashboardAsDirective() {
|
|
export function saveDashboardAsDirective() {
|