diff options
author | Kazuki Yamaguchi <k@rhe.jp> | 2017-10-05 15:58:59 +0900 |
---|---|---|
committer | Kazuki Yamaguchi <k@rhe.jp> | 2017-10-05 15:58:59 +0900 |
commit | 9db537d339faa3ad44dfdcadb23f4c14bd8aceb4 (patch) | |
tree | 6b151cdfd0ca7dc44b9a189045b2b2cbc5aefc21 /app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt | |
parent | 52ad6edcb217762154a80990c34ca94772393848 (diff) | |
download | SmileEssence-9db537d339faa3ad44dfdcadb23f4c14bd8aceb4.tar.gz |
kotlin work part. 1
Diffstat (limited to 'app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt')
-rw-r--r-- | app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt b/app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt new file mode 100644 index 00000000..a9bd8fe4 --- /dev/null +++ b/app/src/main/java/net/lacolaco/smileessence/view/page/HomeFragment.kt @@ -0,0 +1,97 @@ +/* + * The MIT License (MIT) + * + * Copyright (c) 2012-2014 lacolaco.net + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + +package net.lacolaco.smileessence.view.page + +import android.os.Bundle +import android.widget.ListView +import com.handmark.pulltorefresh.library.PullToRefreshBase +import net.lacolaco.smileessence.Application +import net.lacolaco.smileessence.R +import net.lacolaco.smileessence.activity.MainActivity +import net.lacolaco.smileessence.entity.Tweet +import net.lacolaco.smileessence.logging.Logger +import net.lacolaco.smileessence.twitter.task.TimelineTask +import net.lacolaco.smileessence.twitter.task.Timelines +import net.lacolaco.smileessence.util.UIHandler +import net.lacolaco.smileessence.view.adapter.TimelineAdapter + +class HomeFragment : CustomListFragment<TimelineAdapter>() { + override val refreshMode: PullToRefreshBase.Mode + get() = PullToRefreshBase.Mode.BOTH + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + adapter = TimelineAdapter(activity) + + world.addTimeline(this) { tweet -> + adapter.add(tweet) + adapter.update() + } + + refresh() + } + + override fun refresh() { + runRefreshTask(Timelines.HomeTimelineTask(world.account), { adapter.updateForce() }) + } + + // --------------------- Interface OnRefreshListener2 --------------------- + + override fun onPullDownToRefresh(refreshView: PullToRefreshBase<ListView>) { + if (world.isStreaming) { + UIHandler().post { + updateListViewWithNotice(refreshView.refreshableView, true) + refreshView.onRefreshComplete() + } + } else { + runRefreshTask( + Timelines.HomeTimelineTask(world.account) + .setSinceId(adapter.topID), + { + updateListViewWithNotice(refreshView.refreshableView, true) + refreshView.onRefreshComplete() + }) + } + } + + override fun onPullUpToRefresh(refreshView: PullToRefreshBase<ListView>) { + runRefreshTask( + Timelines.HomeTimelineTask(world.account) + .setMaxId(adapter.lastID - 1), + { + updateListViewWithNotice(refreshView.refreshableView, false) + refreshView.onRefreshComplete() + }) + } + + private fun runRefreshTask(task: TimelineTask<Tweet>, onFinish: () -> Unit) { + task + .setCount(200) + .onFail { e -> world.notifyError(R.string.notice_error_get_home) } + .onDoneUI { tweets -> world.addTweetAll(tweets) } + .onFinishUI(onFinish) + .execute() + } +} |