use of android.support.v7.widget.helper.ItemTouchHelper.UP in project UltimateAndroid by cymcsg.
the class StaggeredGridLayoutManager method moveLayoutToPosition.
@Override
void moveLayoutToPosition(int position, int offset, Recycler recycler, State state) {
final boolean isVertical = isVertical();
final Lanes lanes = getLanes();
lanes.reset(0);
for (int i = 0; i <= position; i++) {
StaggeredItemEntry entry = (StaggeredItemEntry) getItemEntryForPosition(i);
if (entry != null) {
mTempLaneInfo.set(entry.startLane, entry.anchorLane);
// removed item. See BaseLayoutManager.invalidateItemLanes().
if (mTempLaneInfo.isUndefined()) {
lanes.findLane(mTempLaneInfo, getLaneSpanForPosition(i), Direction.END);
entry.setLane(mTempLaneInfo);
}
lanes.getChildFrame(mTempRect, entry.width, entry.height, mTempLaneInfo, Direction.END);
} else {
final View child = recycler.getViewForPosition(i);
// XXX: This might potentially cause stalls in the main
// thread if the layout ends up having to measure tons of
// child views. We might need to add different policies based
// on known assumptions regarding certain layouts e.g. child
// views have stable aspect ratio, lane size is fixed, etc.
measureChild(child, Direction.END);
// The measureChild() call ensures an entry is created for
// this position.
entry = (StaggeredItemEntry) getItemEntryForPosition(i);
mTempLaneInfo.set(entry.startLane, entry.anchorLane);
lanes.getChildFrame(mTempRect, getDecoratedMeasuredWidth(child), getDecoratedMeasuredHeight(child), mTempLaneInfo, Direction.END);
cacheItemFrame(entry, mTempRect);
}
if (i != position) {
pushChildFrame(entry, mTempRect, entry.startLane, entry.span, Direction.END);
}
}
lanes.getLane(mTempLaneInfo.startLane, mTempRect);
lanes.reset(Direction.END);
lanes.offset(offset - (isVertical ? mTempRect.bottom : mTempRect.right));
}
use of android.support.v7.widget.helper.ItemTouchHelper.UP in project FastAdapter by mikepenz.
the class MultiselectSampleActivity method onCreate.
@Override
protected void onCreate(Bundle savedInstanceState) {
findViewById(android.R.id.content).setSystemUiVisibility(findViewById(android.R.id.content).getSystemUiVisibility() | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sample);
// Handle Toolbar
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setTitle(R.string.sample_multi_select);
//style our ui
new MaterializeBuilder().withActivity(this).build();
//create our FastAdapter
mFastAdapter = new FastAdapter<>();
//
mUndoHelper = new UndoHelper(mFastAdapter, new UndoHelper.UndoListener<SimpleItem>() {
@Override
public void commitRemove(Set<Integer> positions, ArrayList<FastAdapter.RelativeInfo<SimpleItem>> removed) {
Log.e("UndoHelper", "Positions: " + positions.toString() + " Removed: " + removed.size());
}
});
//we init our ActionModeHelper
mActionModeHelper = new ActionModeHelper(mFastAdapter, R.menu.cab, new ActionBarCallBack());
//create our adapters
ItemAdapter<SimpleItem> itemAdapter = new ItemAdapter<>();
final HeaderAdapter<SimpleItem> headerAdapter = new HeaderAdapter<>();
//configure our mFastAdapter
//as we provide id's for the items we want the hasStableIds enabled to speed up things
mFastAdapter.setHasStableIds(true);
mFastAdapter.withSelectable(true);
mFastAdapter.withMultiSelect(true);
mFastAdapter.withSelectOnLongClick(true);
mFastAdapter.withOnPreClickListener(new FastAdapter.OnClickListener<SimpleItem>() {
@Override
public boolean onClick(View v, IAdapter<SimpleItem> adapter, SimpleItem item, int position) {
//we handle the default onClick behavior for the actionMode. This will return null if it didn't do anything and you can handle a normal onClick
Boolean res = mActionModeHelper.onClick(item);
return res != null ? res : false;
}
});
mFastAdapter.withOnClickListener(new FastAdapter.OnClickListener<SimpleItem>() {
@Override
public boolean onClick(View v, IAdapter<SimpleItem> adapter, SimpleItem item, int position) {
Toast.makeText(v.getContext(), "SelectedCount: " + mFastAdapter.getSelections().size() + " ItemsCount: " + mFastAdapter.getSelectedItems().size(), Toast.LENGTH_SHORT).show();
return false;
}
});
mFastAdapter.withOnPreLongClickListener(new FastAdapter.OnLongClickListener<SimpleItem>() {
@Override
public boolean onLongClick(View v, IAdapter<SimpleItem> adapter, SimpleItem item, int position) {
ActionMode actionMode = mActionModeHelper.onLongClick(MultiselectSampleActivity.this, position);
if (actionMode != null) {
//we want color our CAB
findViewById(R.id.action_mode_bar).setBackgroundColor(UIUtils.getThemeColorFromAttrOrRes(MultiselectSampleActivity.this, R.attr.colorPrimary, R.color.material_drawer_primary));
}
//if we have no actionMode we do not consume the event
return actionMode != null;
}
});
//get our recyclerView and do basic setup
RecyclerView rv = (RecyclerView) findViewById(R.id.rv);
rv.setLayoutManager(new LinearLayoutManager(this));
rv.setItemAnimator(new SlideDownAlphaAnimator());
rv.setAdapter(itemAdapter.wrap(headerAdapter.wrap(mFastAdapter)));
//fill with some sample data
SimpleItem SimpleItem = new SimpleItem();
SimpleItem.withName("Header").withIdentifier(1).withSelectable(false);
headerAdapter.add(SimpleItem);
List<SimpleItem> items = new ArrayList<>();
for (int i = 1; i <= 100; i++) {
SimpleItem item = new SimpleItem();
item.withName("Test " + i).withIdentifier(100 + i);
items.add(item);
}
itemAdapter.add(items);
//restore selections (this has to be done after the items were added
mFastAdapter.withSavedInstanceState(savedInstanceState);
//set the back arrow in the toolbar
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setHomeButtonEnabled(false);
//inform that longClick is required
Toast.makeText(this, "LongClick to enable Multi-Selection", Toast.LENGTH_LONG).show();
}
use of android.support.v7.widget.helper.ItemTouchHelper.UP in project FastAdapter by mikepenz.
the class StickyHeaderSampleActivity method onCreate.
@Override
protected void onCreate(Bundle savedInstanceState) {
findViewById(android.R.id.content).setSystemUiVisibility(findViewById(android.R.id.content).getSystemUiVisibility() | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sample);
// Handle Toolbar
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setTitle(R.string.sample_sticky_header);
//style our ui
new MaterializeBuilder().withActivity(this).build();
//create our FastAdapter
fastAdapter = new FastAdapter();
fastAdapter.withSelectable(true);
//create our adapters
final StickyHeaderAdapter stickyHeaderAdapter = new StickyHeaderAdapter();
final HeaderAdapter headerAdapter = new HeaderAdapter();
final ItemAdapter itemAdapter = new ItemAdapter();
//configure our fastAdapter
//as we provide id's for the items we want the hasStableIds enabled to speed up things
fastAdapter.setHasStableIds(true);
//get our recyclerView and do basic setup
RecyclerView rv = (RecyclerView) findViewById(R.id.rv);
rv.setLayoutManager(new LinearLayoutManager(this));
rv.setItemAnimator(new DefaultItemAnimator());
rv.setAdapter(stickyHeaderAdapter.wrap(itemAdapter.wrap(headerAdapter.wrap(fastAdapter))));
//this adds the Sticky Headers within our list
final StickyRecyclerHeadersDecoration decoration = new StickyRecyclerHeadersDecoration(stickyHeaderAdapter);
rv.addItemDecoration(decoration);
//fill with some sample data
headerAdapter.add(new SimpleItem().withName("Header").withIdentifier(1));
List<IItem> items = new ArrayList<>();
for (int i = 1; i <= 100; i++) {
items.add(new SimpleItem().withName("Test " + i).withHeader(headers[i / 5]).withIdentifier(100 + i));
}
itemAdapter.add(items);
//so the headers are aware of changes
stickyHeaderAdapter.registerAdapterDataObserver(new RecyclerView.AdapterDataObserver() {
@Override
public void onChanged() {
decoration.invalidateHeaders();
}
});
//restore selections (this has to be done after the items were added
fastAdapter.withSavedInstanceState(savedInstanceState);
//set the back arrow in the toolbar
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setHomeButtonEnabled(false);
}
use of android.support.v7.widget.helper.ItemTouchHelper.UP in project FastAdapter by mikepenz.
the class AdvancedSampleActivity method onCreate.
@Override
protected void onCreate(Bundle savedInstanceState) {
findViewById(android.R.id.content).setSystemUiVisibility(findViewById(android.R.id.content).getSystemUiVisibility() | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
//as we use an icon from Android-Iconics via xml we add the IconicsLayoutInflater
//https://github.com/mikepenz/Android-Iconics
LayoutInflaterCompat.setFactory(getLayoutInflater(), new IconicsLayoutInflater(getDelegate()));
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sample);
// Handle Toolbar
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setTitle(R.string.sample_advanced);
//style our ui
new MaterializeBuilder().withActivity(this).build();
//create our FastAdapter
mFastAdapter = new FastAdapter<>();
//we init our ActionModeHelper
mActionModeHelper = new ActionModeHelper(mFastAdapter, R.menu.cab, new ActionBarCallBack());
mActionModeHelper.withSupportSubItems(true);
//create our adapters
final StickyHeaderAdapter stickyHeaderAdapter = new StickyHeaderAdapter();
mItemAdapter = new ItemAdapter<>();
mHeaderAdapter = new HeaderAdapter<>();
//configure our mFastAdapter
//as we provide id's for the items we want the hasStableIds enabled to speed up things
mFastAdapter.withSelectable(true);
mFastAdapter.withMultiSelect(true);
mFastAdapter.withSelectOnLongClick(true);
mFastAdapter.withPositionBasedStateManagement(false);
mFastAdapter.withOnPreClickListener(new FastAdapter.OnClickListener<IItem>() {
@Override
public boolean onClick(View v, IAdapter adapter, IItem item, int position) {
//we handle the default onClick behavior for the actionMode. This will return null if it didn't do anything and you can handle a normal onClick
Boolean res = mActionModeHelper.onClick(item);
return res != null ? res : false;
}
});
mFastAdapter.withOnPreLongClickListener(new FastAdapter.OnLongClickListener<IItem>() {
@Override
public boolean onLongClick(View v, IAdapter adapter, IItem item, int position) {
//we do not want expandable items to be selected
if (item instanceof IExpandable) {
if (((IExpandable) item).getSubItems() != null) {
return true;
}
}
//handle the longclick actions
ActionMode actionMode = mActionModeHelper.onLongClick(AdvancedSampleActivity.this, position);
if (actionMode != null) {
//we want color our CAB
findViewById(R.id.action_mode_bar).setBackgroundColor(UIUtils.getThemeColorFromAttrOrRes(AdvancedSampleActivity.this, R.attr.colorPrimary, R.color.material_drawer_primary));
}
//if we have no actionMode we do not consume the event
return actionMode != null;
}
});
//get our recyclerView and do basic setup
RecyclerView rv = (RecyclerView) findViewById(R.id.rv);
rv.setLayoutManager(new LinearLayoutManager(this));
rv.setItemAnimator(new DefaultItemAnimator());
rv.setAdapter(stickyHeaderAdapter.wrap(mItemAdapter.wrap(mHeaderAdapter.wrap(mFastAdapter))));
final StickyRecyclerHeadersDecoration decoration = new StickyRecyclerHeadersDecoration(stickyHeaderAdapter);
rv.addItemDecoration(decoration);
//so the headers are aware of changes
stickyHeaderAdapter.registerAdapterDataObserver(new RecyclerView.AdapterDataObserver() {
@Override
public void onChanged() {
decoration.invalidateHeaders();
}
});
//init cache with the added items, this is useful for shorter lists with many many different view types (at least 4 or more
//new RecyclerViewCacheUtil().withCacheSize(2).apply(rv, items);
//set the back arrow in the toolbar
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setHomeButtonEnabled(false);
//we define the items
setItems();
//restore selections (this has to be done after the items were added
mFastAdapter.withSavedInstanceState(savedInstanceState);
}
use of android.support.v7.widget.helper.ItemTouchHelper.UP in project material-dialogs by afollestad.
the class DialogInit method init.
@SuppressWarnings("ConstantConditions")
@UiThread
public static void init(final MaterialDialog dialog) {
final MaterialDialog.Builder builder = dialog.builder;
// Set cancelable flag and dialog background color
dialog.setCancelable(builder.cancelable);
dialog.setCanceledOnTouchOutside(builder.canceledOnTouchOutside);
if (builder.backgroundColor == 0) {
builder.backgroundColor = DialogUtils.resolveColor(builder.context, R.attr.md_background_color, DialogUtils.resolveColor(dialog.getContext(), R.attr.colorBackgroundFloating));
}
if (builder.backgroundColor != 0) {
GradientDrawable drawable = new GradientDrawable();
drawable.setCornerRadius(builder.context.getResources().getDimension(R.dimen.md_bg_corner_radius));
drawable.setColor(builder.backgroundColor);
dialog.getWindow().setBackgroundDrawable(drawable);
}
// Retrieve color theme attributes
if (!builder.positiveColorSet) {
builder.positiveColor = DialogUtils.resolveActionTextColorStateList(builder.context, R.attr.md_positive_color, builder.positiveColor);
}
if (!builder.neutralColorSet) {
builder.neutralColor = DialogUtils.resolveActionTextColorStateList(builder.context, R.attr.md_neutral_color, builder.neutralColor);
}
if (!builder.negativeColorSet) {
builder.negativeColor = DialogUtils.resolveActionTextColorStateList(builder.context, R.attr.md_negative_color, builder.negativeColor);
}
if (!builder.widgetColorSet) {
builder.widgetColor = DialogUtils.resolveColor(builder.context, R.attr.md_widget_color, builder.widgetColor);
}
// Retrieve default title/content colors
if (!builder.titleColorSet) {
final int titleColorFallback = DialogUtils.resolveColor(dialog.getContext(), android.R.attr.textColorPrimary);
builder.titleColor = DialogUtils.resolveColor(builder.context, R.attr.md_title_color, titleColorFallback);
}
if (!builder.contentColorSet) {
final int contentColorFallback = DialogUtils.resolveColor(dialog.getContext(), android.R.attr.textColorSecondary);
builder.contentColor = DialogUtils.resolveColor(builder.context, R.attr.md_content_color, contentColorFallback);
}
if (!builder.itemColorSet) {
builder.itemColor = DialogUtils.resolveColor(builder.context, R.attr.md_item_color, builder.contentColor);
}
// Retrieve references to views
dialog.title = (TextView) dialog.view.findViewById(R.id.md_title);
dialog.icon = (ImageView) dialog.view.findViewById(R.id.md_icon);
dialog.titleFrame = dialog.view.findViewById(R.id.md_titleFrame);
dialog.content = (TextView) dialog.view.findViewById(R.id.md_content);
dialog.recyclerView = (RecyclerView) dialog.view.findViewById(R.id.md_contentRecyclerView);
dialog.checkBoxPrompt = (CheckBox) dialog.view.findViewById(R.id.md_promptCheckbox);
// Button views initially used by checkIfStackingNeeded()
dialog.positiveButton = (MDButton) dialog.view.findViewById(R.id.md_buttonDefaultPositive);
dialog.neutralButton = (MDButton) dialog.view.findViewById(R.id.md_buttonDefaultNeutral);
dialog.negativeButton = (MDButton) dialog.view.findViewById(R.id.md_buttonDefaultNegative);
// Don't allow the submit button to not be shown for input dialogs
if (builder.inputCallback != null && builder.positiveText == null) {
builder.positiveText = builder.context.getText(android.R.string.ok);
}
// Set up the initial visibility of action buttons based on whether or not text was set
dialog.positiveButton.setVisibility(builder.positiveText != null ? View.VISIBLE : View.GONE);
dialog.neutralButton.setVisibility(builder.neutralText != null ? View.VISIBLE : View.GONE);
dialog.negativeButton.setVisibility(builder.negativeText != null ? View.VISIBLE : View.GONE);
// Set up the focus of action buttons
dialog.positiveButton.setFocusable(true);
dialog.neutralButton.setFocusable(true);
dialog.negativeButton.setFocusable(true);
if (builder.positiveFocus) {
dialog.positiveButton.requestFocus();
}
if (builder.neutralFocus) {
dialog.neutralButton.requestFocus();
}
if (builder.negativeFocus) {
dialog.negativeButton.requestFocus();
}
// Setup icon
if (builder.icon != null) {
dialog.icon.setVisibility(View.VISIBLE);
dialog.icon.setImageDrawable(builder.icon);
} else {
Drawable d = DialogUtils.resolveDrawable(builder.context, R.attr.md_icon);
if (d != null) {
dialog.icon.setVisibility(View.VISIBLE);
dialog.icon.setImageDrawable(d);
} else {
dialog.icon.setVisibility(View.GONE);
}
}
// Setup icon size limiting
int maxIconSize = builder.maxIconSize;
if (maxIconSize == -1) {
maxIconSize = DialogUtils.resolveDimension(builder.context, R.attr.md_icon_max_size);
}
if (builder.limitIconToDefaultSize || DialogUtils.resolveBoolean(builder.context, R.attr.md_icon_limit_icon_to_default_size)) {
maxIconSize = builder.context.getResources().getDimensionPixelSize(R.dimen.md_icon_max_size);
}
if (maxIconSize > -1) {
dialog.icon.setAdjustViewBounds(true);
dialog.icon.setMaxHeight(maxIconSize);
dialog.icon.setMaxWidth(maxIconSize);
dialog.icon.requestLayout();
}
// Setup divider color in case content scrolls
if (!builder.dividerColorSet) {
final int dividerFallback = DialogUtils.resolveColor(dialog.getContext(), R.attr.md_divider);
builder.dividerColor = DialogUtils.resolveColor(builder.context, R.attr.md_divider_color, dividerFallback);
}
dialog.view.setDividerColor(builder.dividerColor);
// Setup title and title frame
if (dialog.title != null) {
dialog.setTypeface(dialog.title, builder.mediumFont);
dialog.title.setTextColor(builder.titleColor);
dialog.title.setGravity(builder.titleGravity.getGravityInt());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
//noinspection ResourceType
dialog.title.setTextAlignment(builder.titleGravity.getTextAlignment());
}
if (builder.title == null) {
dialog.titleFrame.setVisibility(View.GONE);
} else {
dialog.title.setText(builder.title);
dialog.titleFrame.setVisibility(View.VISIBLE);
}
}
// Setup content
if (dialog.content != null) {
dialog.content.setMovementMethod(new LinkMovementMethod());
dialog.setTypeface(dialog.content, builder.regularFont);
dialog.content.setLineSpacing(0f, builder.contentLineSpacingMultiplier);
if (builder.linkColor == null) {
dialog.content.setLinkTextColor(DialogUtils.resolveColor(dialog.getContext(), android.R.attr.textColorPrimary));
} else {
dialog.content.setLinkTextColor(builder.linkColor);
}
dialog.content.setTextColor(builder.contentColor);
dialog.content.setGravity(builder.contentGravity.getGravityInt());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
//noinspection ResourceType
dialog.content.setTextAlignment(builder.contentGravity.getTextAlignment());
}
if (builder.content != null) {
dialog.content.setText(builder.content);
dialog.content.setVisibility(View.VISIBLE);
} else {
dialog.content.setVisibility(View.GONE);
}
}
// Setup prompt checkbox
if (dialog.checkBoxPrompt != null) {
dialog.checkBoxPrompt.setText(builder.checkBoxPrompt);
dialog.checkBoxPrompt.setChecked(builder.checkBoxPromptInitiallyChecked);
dialog.checkBoxPrompt.setOnCheckedChangeListener(builder.checkBoxPromptListener);
dialog.setTypeface(dialog.checkBoxPrompt, builder.regularFont);
dialog.checkBoxPrompt.setTextColor(builder.contentColor);
MDTintHelper.setTint(dialog.checkBoxPrompt, builder.widgetColor);
}
// Setup action buttons
dialog.view.setButtonGravity(builder.buttonsGravity);
dialog.view.setButtonStackedGravity(builder.btnStackedGravity);
dialog.view.setStackingBehavior(builder.stackingBehavior);
boolean textAllCaps;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
textAllCaps = DialogUtils.resolveBoolean(builder.context, android.R.attr.textAllCaps, true);
if (textAllCaps) {
textAllCaps = DialogUtils.resolveBoolean(builder.context, R.attr.textAllCaps, true);
}
} else {
textAllCaps = DialogUtils.resolveBoolean(builder.context, R.attr.textAllCaps, true);
}
MDButton positiveTextView = dialog.positiveButton;
dialog.setTypeface(positiveTextView, builder.mediumFont);
positiveTextView.setAllCapsCompat(textAllCaps);
positiveTextView.setText(builder.positiveText);
positiveTextView.setTextColor(builder.positiveColor);
dialog.positiveButton.setStackedSelector(dialog.getButtonSelector(DialogAction.POSITIVE, true));
dialog.positiveButton.setDefaultSelector(dialog.getButtonSelector(DialogAction.POSITIVE, false));
dialog.positiveButton.setTag(DialogAction.POSITIVE);
dialog.positiveButton.setOnClickListener(dialog);
dialog.positiveButton.setVisibility(View.VISIBLE);
MDButton negativeTextView = dialog.negativeButton;
dialog.setTypeface(negativeTextView, builder.mediumFont);
negativeTextView.setAllCapsCompat(textAllCaps);
negativeTextView.setText(builder.negativeText);
negativeTextView.setTextColor(builder.negativeColor);
dialog.negativeButton.setStackedSelector(dialog.getButtonSelector(DialogAction.NEGATIVE, true));
dialog.negativeButton.setDefaultSelector(dialog.getButtonSelector(DialogAction.NEGATIVE, false));
dialog.negativeButton.setTag(DialogAction.NEGATIVE);
dialog.negativeButton.setOnClickListener(dialog);
dialog.negativeButton.setVisibility(View.VISIBLE);
MDButton neutralTextView = dialog.neutralButton;
dialog.setTypeface(neutralTextView, builder.mediumFont);
neutralTextView.setAllCapsCompat(textAllCaps);
neutralTextView.setText(builder.neutralText);
neutralTextView.setTextColor(builder.neutralColor);
dialog.neutralButton.setStackedSelector(dialog.getButtonSelector(DialogAction.NEUTRAL, true));
dialog.neutralButton.setDefaultSelector(dialog.getButtonSelector(DialogAction.NEUTRAL, false));
dialog.neutralButton.setTag(DialogAction.NEUTRAL);
dialog.neutralButton.setOnClickListener(dialog);
dialog.neutralButton.setVisibility(View.VISIBLE);
// Setup list dialog stuff
if (builder.listCallbackMultiChoice != null) {
dialog.selectedIndicesList = new ArrayList<>();
}
if (dialog.recyclerView != null) {
if (builder.adapter == null) {
// Determine list type
if (builder.listCallbackSingleChoice != null) {
dialog.listType = MaterialDialog.ListType.SINGLE;
} else if (builder.listCallbackMultiChoice != null) {
dialog.listType = MaterialDialog.ListType.MULTI;
if (builder.selectedIndices != null) {
dialog.selectedIndicesList = new ArrayList<>(Arrays.asList(builder.selectedIndices));
builder.selectedIndices = null;
}
} else {
dialog.listType = MaterialDialog.ListType.REGULAR;
}
builder.adapter = new DefaultRvAdapter(dialog, MaterialDialog.ListType.getLayoutForType(dialog.listType));
} else if (builder.adapter instanceof MDAdapter) {
// Notify simple list adapter of the dialog it belongs to
((MDAdapter) builder.adapter).setDialog(dialog);
}
}
// Setup progress dialog stuff if needed
setupProgressDialog(dialog);
// Setup input dialog stuff if needed
setupInputDialog(dialog);
// Setup custom views
if (builder.customView != null) {
((MDRootLayout) dialog.view.findViewById(R.id.md_root)).noTitleNoPadding();
FrameLayout frame = (FrameLayout) dialog.view.findViewById(R.id.md_customViewFrame);
dialog.customViewFrame = frame;
View innerView = builder.customView;
if (innerView.getParent() != null) {
((ViewGroup) innerView.getParent()).removeView(innerView);
}
if (builder.wrapCustomViewInScroll) {
/* Apply the frame padding to the content, this allows the ScrollView to draw it's
over scroll glow without clipping */
final Resources r = dialog.getContext().getResources();
final int framePadding = r.getDimensionPixelSize(R.dimen.md_dialog_frame_margin);
final ScrollView sv = new ScrollView(dialog.getContext());
int paddingTop = r.getDimensionPixelSize(R.dimen.md_content_padding_top);
int paddingBottom = r.getDimensionPixelSize(R.dimen.md_content_padding_bottom);
sv.setClipToPadding(false);
if (innerView instanceof EditText) {
// Setting padding to an EditText causes visual errors, set it to the parent instead
sv.setPadding(framePadding, paddingTop, framePadding, paddingBottom);
} else {
// Setting padding to scroll view pushes the scroll bars out, don't do it if not necessary (like above)
sv.setPadding(0, paddingTop, 0, paddingBottom);
innerView.setPadding(framePadding, 0, framePadding, 0);
}
sv.addView(innerView, new ScrollView.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
innerView = sv;
}
frame.addView(innerView, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
}
// Setup user listeners
if (builder.showListener != null) {
dialog.setOnShowListener(builder.showListener);
}
if (builder.cancelListener != null) {
dialog.setOnCancelListener(builder.cancelListener);
}
if (builder.dismissListener != null) {
dialog.setOnDismissListener(builder.dismissListener);
}
if (builder.keyListener != null) {
dialog.setOnKeyListener(builder.keyListener);
}
// Setup internal show listener
dialog.setOnShowListenerInternal();
// Other internal initialization
dialog.invalidateList();
dialog.setViewInternal(dialog.view);
dialog.checkIfListInitScroll();
// Min height and max width calculations
WindowManager wm = dialog.getWindow().getWindowManager();
Display display = wm.getDefaultDisplay();
Point size = new Point();
display.getSize(size);
final int windowWidth = size.x;
final int windowHeight = size.y;
final int windowVerticalPadding = builder.context.getResources().getDimensionPixelSize(R.dimen.md_dialog_vertical_margin);
final int windowHorizontalPadding = builder.context.getResources().getDimensionPixelSize(R.dimen.md_dialog_horizontal_margin);
final int maxWidth = builder.context.getResources().getDimensionPixelSize(R.dimen.md_dialog_max_width);
final int calculatedWidth = windowWidth - (windowHorizontalPadding * 2);
dialog.view.setMaxHeight(windowHeight - windowVerticalPadding * 2);
WindowManager.LayoutParams lp = new WindowManager.LayoutParams();
lp.copyFrom(dialog.getWindow().getAttributes());
lp.width = Math.min(maxWidth, calculatedWidth);
dialog.getWindow().setAttributes(lp);
}
Aggregations