[NIFI-6639] consistent ux for checkboxes and their correspoinding field

This closes #3706
This commit is contained in:
Scott Aslan 2019-09-06 13:29:48 -04:00 committed by Matt Gilman
parent 758035b964
commit 250e1b0297
No known key found for this signature in database
GPG Key ID: DF61EC19432AEE37
3 changed files with 59 additions and 11 deletions

View File

@ -171,7 +171,6 @@ ul.links span.header-link-over {
font-weight: bold !important; font-weight: bold !important;
} }
.ellipsis { .ellipsis {
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
@ -261,6 +260,12 @@ textarea {
text-overflow: ellipsis; text-overflow: ellipsis;
} }
textarea[disabled] {
background: #b2b8c1;
color: #dbdee2;
border: 1px solid #b2b8c1;
}
ul.property-info { ul.property-info {
list-style-type: disc; list-style-type: disc;
margin-left: 10px; margin-left: 10px;

View File

@ -233,6 +233,7 @@
$('#parameter-sensitive-radio-button').prop('disabled', false); $('#parameter-sensitive-radio-button').prop('disabled', false);
$('#parameter-not-sensitive-radio-button').prop('disabled', false); $('#parameter-not-sensitive-radio-button').prop('disabled', false);
$('#parameter-set-empty-string-field').removeClass('checkbox-checked').addClass('checkbox-unchecked'); $('#parameter-set-empty-string-field').removeClass('checkbox-checked').addClass('checkbox-unchecked');
$('#parameter-value-field').prop('disabled', false);
}; };
/** /**
@ -912,7 +913,7 @@
} }
// validate the parameter is not a duplicate // validate the parameter is not a duplicate
var matchingParameter = _.find(existingParameters, { name: parameter.name }); var matchingParameter = _.find(existingParameters, {name: parameter.name});
// Valid if no duplicate is found or it is edit mode and a matching parameter was found // Valid if no duplicate is found or it is edit mode and a matching parameter was found
if (_.isNil(matchingParameter) || (editMode === true && !_.isNil(matchingParameter))) { if (_.isNil(matchingParameter) || (editMode === true && !_.isNil(matchingParameter))) {
@ -1649,6 +1650,18 @@
$('#parameter-dialog').modal('refreshButtons'); $('#parameter-dialog').modal('refreshButtons');
}; };
$('#parameter-set-empty-string-field').off().on('change', function (event, args) {
// if we are setting as an empty string, disable the editor
if (args.isChecked) {
$('#parameter-value-field').prop('disabled', true).val('');
$('#parameter-dialog').modal('refreshButtons');
} else {
var value = parameter.sensitive ? '' : parameter.previousValue;
$('#parameter-value-field').prop('disabled', false).val(value);
$('#parameter-dialog').modal('refreshButtons');
}
});
$('#parameter-dialog') $('#parameter-dialog')
.modal('setHeaderText', 'Edit Parameter') .modal('setHeaderText', 'Edit Parameter')
.modal('setOpenHandler', openHandler) .modal('setOpenHandler', openHandler)
@ -1875,6 +1888,17 @@
.modal('show'); .modal('show');
}); });
$('#parameter-set-empty-string-field').off().on('change', function (event, args) {
// if we are setting as an empty string, disable the editor
if (args.isChecked) {
$('#parameter-value-field').prop('disabled', true).val('');
$('#parameter-dialog').modal('refreshButtons');
} else {
$('#parameter-value-field').prop('disabled', false);
$('#parameter-dialog').modal('refreshButtons');
}
});
$('#parameter-context-name').on('keyup', function (evt) { $('#parameter-context-name').on('keyup', function (evt) {
// update the buttons to possibly trigger the disabled state // update the buttons to possibly trigger the disabled state
$('#parameter-context-dialog').modal('refreshButtons'); $('#parameter-context-dialog').modal('refreshButtons');
@ -1956,6 +1980,17 @@
} }
}]) }])
.modal('show'); .modal('show');
$('#parameter-set-empty-string-field').off().on('change', function (event, args) {
// if we are setting as an empty string, disable the editor
if (args.isChecked) {
$('#parameter-value-field').prop('disabled', true).val('');
$('#parameter-dialog').modal('refreshButtons');
} else {
$('#parameter-value-field').prop('disabled', false);
$('#parameter-dialog').modal('refreshButtons');
}
});
}; };
/** /**
@ -2559,7 +2594,7 @@
// initiate the parameter context update with the new parameter // initiate the parameter context update with the new parameter
submitUpdateRequest(parameterContextEntity) submitUpdateRequest(parameterContextEntity)
.done(function(response) { .done(function (response) {
var pollUpdateRequest = function (updateRequestEntity) { var pollUpdateRequest = function (updateRequestEntity) {
var updateRequest = updateRequestEntity.request; var updateRequest = updateRequestEntity.request;
var errored = !_.isEmpty(updateRequest.failureReason); var errored = !_.isEmpty(updateRequest.failureReason);
@ -2611,7 +2646,7 @@
deferred.reject(e) deferred.reject(e)
}); });
}, },
onCancel: function() { onCancel: function () {
showUpdateStatus(false); showUpdateStatus(false);
if (!_.isNil(parameterContextEntity.id) && !_.isNil(requestId)) { if (!_.isNil(parameterContextEntity.id) && !_.isNil(requestId)) {
@ -2653,7 +2688,7 @@
// update the buttons to possibly trigger the disabled state // update the buttons to possibly trigger the disabled state
$('#parameter-dialog').modal('refreshButtons'); $('#parameter-dialog').modal('refreshButtons');
}) })
.fail(function(e) { .fail(function (e) {
deferred.reject(e); deferred.reject(e);
}); });
}).promise(); }).promise();

View File

@ -124,7 +124,15 @@
stringCheckPanel.appendTo(wrapper); stringCheckPanel.appendTo(wrapper);
// build the custom checkbox // build the custom checkbox
isEmpty = $('<div class="nf-checkbox string-check"/>').appendTo(stringCheckPanel); isEmpty = $('<div class="nf-checkbox string-check"/>')
.on('change', function (event, args) {
// if we are setting as an empty string, disable the editor
if (args.isChecked) {
input.prop('disabled', true).val('');
} else {
input.prop('disabled', false).val(previousValue);
}
}).appendTo(stringCheckPanel);
$('<span class="string-check-label nf-checkbox-label">&nbsp;Set empty string</span>').appendTo(stringCheckPanel); $('<span class="string-check-label nf-checkbox-label">&nbsp;Set empty string</span>').appendTo(stringCheckPanel);
var ok = $('<div class="button">Ok</div>').css({ var ok = $('<div class="button">Ok</div>').css({