Вы говорите, если кнопка нажата, но в вашем примере все кнопки в списке будут отключены. Попробуйте связать слушателя с каждой кнопкой, а не просто отключить его.
Для логики вы имеете в виду что-то вроде этого:
Arrays.asList(buttons).forEach(
button -> button.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
button.setEnabled(false);
}
}));
Мне также нравится ответ Седрика, но у вас есть для добавления прослушивателя действий внутри цикла.
Хорошо, похоже, я понял это сам. Надеюсь, что это помогает другим людям.
from bokeh.plotting import figure, output_file, show, ColumnDataSource
from bokeh.models import CustomJS, Button
from bokeh.layouts import row, column
x = ['asset1']
source= ColumnDataSource(data=dict(x=x))
callback = CustomJS(args=dict(source=source), code="""
var data = source.data;
var input = cb_obj.value;
data['x']=input;
source.change.emit();
""")
assets=['asset1','asset2','asset3','asset4']
multi_select1 = MultiSelect(title="Select:", value=['asset1'],options=assets, height=200, width=100)
multi_select1.js_on_change('value', callback)
savebutton = Button(label="Save", button_type="success")
savebutton.callback = CustomJS(args=dict(source=source), code="""
var data = source.data;
value1=data['x'];
var out = "";
for (i = 0; i < value1.length; i++) {
out += value1[i];
}
var file = new Blob([out], {type: 'text/plain'});
var elem = window.document.createElement('a');
elem.href = window.URL.createObjectURL(file);
elem.download = 'selected-data.txt';
document.body.appendChild(elem);
elem.click();
document.body.removeChild(elem);
""")
plot = column(multi_select1,savebutton)
show(plot)