123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- /*
- * Copyright 2000-2014 Vaadin Ltd.
- *
- * Licensed under the Apache License, Version 2.0 (the "License"); you may not
- * use this file except in compliance with the License. You may obtain a copy of
- * the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
- * License for the specific language governing permissions and limitations under
- * the License.
- */
- package com.vaadin.client.connectors.components;
-
- import java.util.logging.Logger;
-
- import com.google.gwt.event.dom.client.ChangeEvent;
- import com.google.gwt.event.dom.client.ChangeHandler;
- import com.google.gwt.user.client.ui.ListBox;
- import com.vaadin.client.connectors.data.HasSelection;
- import com.vaadin.client.data.DataChangeHandler;
- import com.vaadin.client.data.DataSource;
- import com.vaadin.client.data.selection.SelectionModel;
- import com.vaadin.client.ui.AbstractComponentConnector;
- import com.vaadin.shared.ui.Connect;
- import com.vaadin.ui.components.nativeselect.NativeSelect;
-
- import elemental.json.JsonObject;
-
- @Connect(NativeSelect.class)
- public class NativeSelectConnector extends AbstractComponentConnector implements
- HasSelection {
-
- private final class NativeSelectDataChangeHandler implements
- DataChangeHandler {
- @Override
- public void resetDataAndSize(int estimatedNewDataSize) {
- resetContent();
- }
-
- @Override
- public void dataUpdated(int firstRowIndex, int numberOfRows) {
- for (int i = 0; i < numberOfRows; ++i) {
- int index = i + firstRowIndex;
- JsonObject item = dataSource.getRow(index);
- getWidget().setItemText(index, item.getString("n"));
- getWidget().setValue(index, item.getString("k"));
- }
- }
-
- @Override
- public void dataRemoved(int firstRowIndex, int numberOfRows) {
- for (int i = 0; i < numberOfRows; ++i) {
- int index = i + firstRowIndex;
- getWidget().removeItem(index);
- }
- }
-
- @Override
- public void dataAvailable(int firstRowIndex, int numberOfRows) {
- // NO-OP
- }
-
- @Override
- public void dataAdded(int firstRowIndex, int numberOfRows) {
- if (getWidget().getItemCount() == firstRowIndex) {
- for (int i = 0; i < numberOfRows; ++i) {
- JsonObject item = dataSource.getRow(i + firstRowIndex);
- Logger.getLogger("foo").warning(item.toJson());
- getWidget().addItem(item.getString("n"),
- item.getString("k"));
- }
- } else {
- resetContent();
- }
- }
- }
-
- private DataSource<JsonObject> dataSource;
- private SelectionModel selectionModel;
-
- @Override
- public ListBox getWidget() {
- return (ListBox) super.getWidget();
- }
-
- @Override
- protected void init() {
- super.init();
-
- getWidget().addChangeHandler(new ChangeHandler() {
-
- @Override
- public void onChange(ChangeEvent event) {
- if (selectionModel == null) {
- return;
- }
- int index = getWidget().getSelectedIndex();
- JsonObject selected = dataSource.getRow(index);
- selectionModel.select(selected);
- }
- });
- }
-
- @Override
- public void setDataSource(DataSource<JsonObject> dataSource) {
- if (this.dataSource != null) {
- dataSource.setDataChangeHandler(null);
- }
- this.dataSource = dataSource;
- dataSource.setDataChangeHandler(new NativeSelectDataChangeHandler());
- resetContent();
- }
-
- @Override
- public void setSelectionModel(SelectionModel selectionModel) {
- this.selectionModel = selectionModel;
- }
-
- private void resetContent() {
- getWidget().clear();
- for (int i = 0; i < dataSource.size(); ++i) {
- JsonObject item = dataSource.getRow(i);
- getWidget().addItem(item.getString("n"), item.getString("k"));
- }
- }
- }
|