2019-01-18 10:12:08 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* * Copyright 2019 New Vector 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-01-07 18:38:36 +00:00
|
|
|
package im.vector.matrix.android.api.session.room.timeline
|
|
|
|
|
2019-01-16 18:25:43 +00:00
|
|
|
import androidx.lifecycle.LiveData
|
2019-01-07 18:38:36 +00:00
|
|
|
|
2019-01-18 15:26:17 +00:00
|
|
|
/**
|
|
|
|
* This interface defines methods to interact with the timeline. It's implemented at the room level.
|
|
|
|
*/
|
2019-01-07 18:38:36 +00:00
|
|
|
interface TimelineService {
|
|
|
|
|
2019-01-18 15:26:17 +00:00
|
|
|
/**
|
|
|
|
* This is the main method of the service. It allows to listen for live [TimelineData].
|
|
|
|
* It's automatically refreshed as soon as timeline data gets updated, through sync or pagination.
|
|
|
|
*
|
|
|
|
* @param eventId: an optional eventId to start loading timeline around.
|
|
|
|
* @return the [LiveData] of [TimelineData]
|
|
|
|
*/
|
2019-01-07 18:38:36 +00:00
|
|
|
fun timeline(eventId: String? = null): LiveData<TimelineData>
|
|
|
|
|
|
|
|
}
|