Skip to content

Latest commit

 

History

History
135 lines (111 loc) · 4.66 KB

README.md

File metadata and controls

135 lines (111 loc) · 4.66 KB

UniversalPickerDialog

Build Quality Gate Status license 1.0.0

HMOS 3rd party library to make implementing Dialog more easier. It includes two abilities :

  1. Single Picker
  2. Multi picker

Screenshots


Screenshots

Source


This library has been inspired by stfalcon-studio/UniversalPickerDialog

Integration


Maven

<dependency>
  <groupId>dev.applibgroup</groupId>
  <artifactId>universalpickerdialog</artifactId>
  <version>1.0.0</version>
  <type>har</type>
</dependency>

Gradle

implementation 'dev.applibgroup:universalpickerdialog:1.0.0'

From Source

  1. For using UniversalPickerDialog module in sample app, include the source code and add the below dependencies in entry/build.gradle to generate hap/support.har.
    implementation project(path: ':universalpickerdialog')
  2. For using UniversalPickerDialog module in separate application using har file, add the har file in the entry/libs folder and add the dependencies in entry/build.gradle file.
    implementation fileTree(dir: 'libs', include: ['*.har'])

Usages


implement callback interfaces:

public class MainAbilitySlice extends AbilitySlice implements ListContainer.ItemClickedListener,
        UniversalPickerDialog.OnPickListener {

Then implement OnPickListener.onPick(int[], int) method:

@Override
public void onPick(int[] selectedValues, int key) {
    String str = list.get(selectedValues[0]);
    Object obj = array[selectedValues[0]];

    /*do some logic*/
}

Now you can build the dialog and show it. Just add these few lines:

new UniversalPickerDialog.Builder(this)
                .setTitle("UniversalPickerDialog")
                .setListener(this)
                .setInputs(
                        new UniversalPickerDialog.Input(0, list),
                        new UniversalPickerDialog.Input(2, array)
                )
                .show();

Data set is passing to Picker using Input class that supports lists as well as arrays, so no data conversion is required :)). It takes in constructor default item position in carousel as the first argument and data set as the second.

Builder was extended by a many methods for more flexibility and convenience of use. Here's the full list (you can find the javadoc on each of these methods):

new UniversalPickerDialog.Builder(this)
    .setTitle(ResourceTable.String_entry_MainAbility)
    .setTitle("Hello!")
    .setTitleColorRes(ResourceTable.Color_green)
    .setTitleColor(Color.GREEN)
    .setBackgroundColorRes(ResourceTable.Color_white)
    .setBackgroundColor(Color.WHITE)
    .setContentTextColorRes(ResourceTable.Color_green)
    .setContentTextColor(Color.GREEN)
    .setPositiveButtonText(ResourceTable.String_ok_text)
    .setPositiveButtonText("Yep!")
    .setNegativeButtonText(ResourceTable.String_cancel_text)
    .setNegativeButtonText("Nope!")
    .setButtonsColor(Color.GREEN)
    .setButtonsColorRes(ResourceTable.Color_green)
    .setPositiveButtonColorRes(ResourceTable.Color_green)
    .setPositiveButtonColor(Color.GREEN)
    .setNegativeButtonColorRes(ResourceTable.Color_red)
    .setNegativeButtonColor(Color.RED)
    .setContentTextSize(16)
    .setListener(this)
    .setInputs(
        new UniversalPickerDialog.Input(2, list),
        new UniversalPickerDialog.Input(0, array)
    )
    .setKey(123)
    .build()
    .show();

Take a look at the sample project for more information.

License

Copyright (C) 2017 stfalcon.com

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.