Components
View State
View that displays different content based on its state.
Component Status Details
Status component contains a list of checks and completeness that has been tested and owned by each component
Usage
Views are responsible for managing their own state. Android View displays different content based on its state. View state in Legion is implemented based on base components forking from Kennyc1012/MultiStateView with some modification and some improvement.
Legion provides 4 different states, where we can customize activities to each layout state.
Default Content
This is default state provided by Legion.
data:image/s3,"s3://crabby-images/95516/95516cdfc4d79481e906caf451ec9cd8454a9c37" alt="viewstate android default"
Empty
This is state that we can use when we have nothing to show in view.
data:image/s3,"s3://crabby-images/2506a/2506a7ea10934c7b9f879cc2659aa6d41b061ffa" alt="viewstate android empty"
Error
This is state that we can use when we have an error activity in view.
data:image/s3,"s3://crabby-images/59ef9/59ef9a83574749823cdfbde6bb20779dd7003b2b" alt="viewstate android error"
Loading
This is state that we can use when we still waiting for an activity in view.
data:image/s3,"s3://crabby-images/f06f6/f06f63bbd1cc3f704f0cbfc307ab415712e41081" alt="viewstate android loading"
How to use
Static usage in XML
<com.telkom.legion.component.viewstate.LgnViewStateandroid:id="@+id/msvSample"android:layout_width="match_parent"android:layout_height="250dp"app:loadingView="@layout/layout_sample_one"app:errorView="@layout/layout_sample_two"app:emptyView="@layout/layout_sample_three"app:viewState="content"><FrameLayout
Change State
...with(binding) {lifecycleScope.launch { //For sample we use coroutine delay for automatic change state//Change to Content ViewmsvSample.viewState = ViewState.CONTENT// Or Use Extension FunctionmsvSample.showDefaultLayout()delay(1000)ewState.LOADING))) {
Modify Layout In State
...with(binding) {//For sample we use state loading with layout : layout_sample_one.xmlwith(LayoutSampleOneBinding.bind(msvSample.getView(ViewState.LOADING))) {//Do Whatever you want with layout}}...
Attributes
Attribute Name | Xml Attrs | Related method(s) | Description |
---|---|---|---|
View State | app:viewState | viewState | To set View State in Layout |
Loading View | app:loadingView | N/A | To set Loading View Layout |
Empty View | app:emptyView | N/A | To set Empty View Layout |
Error View | app:errorView | N/A | To set Error View Layout |