Search in sources :

Example 1 with RxProviderModule

use of m.co.rh.id.a_medic_log.app.provider.RxProviderModule in project a-medic-log by rh-id.

the class LogPage method createView.

@Override
protected View createView(Activity activity, ViewGroup container) {
    View view = activity.getLayoutInflater().inflate(R.layout.page_log, container, false);
    ViewGroup rootLayout = view.findViewById(R.id.root_layout);
    ViewGroup containerAppBar = view.findViewById(R.id.container_app_bar);
    mAppBarSV.setTitle(activity.getString(R.string.title_log_file));
    containerAppBar.addView(mAppBarSV.buildView(activity, rootLayout));
    ProgressBar progressBar = view.findViewById(R.id.progress_circular);
    View noRecord = view.findViewById(R.id.no_record);
    ScrollView scrollView = view.findViewById(R.id.scroll_view);
    TextView textView = view.findViewById(R.id.text_content);
    Provider provider = BaseApplication.of(activity).getProvider();
    if (mSvProvider != null) {
        mSvProvider.dispose();
    }
    mSvProvider = Provider.createProvider(activity.getApplicationContext(), new RxProviderModule());
    FileHelper fileHelper = provider.get(FileHelper.class);
    File logFile = fileHelper.getLogFile();
    FloatingActionButton fabClear = view.findViewById(R.id.fab_clear);
    FloatingActionButton fabShare = view.findViewById(R.id.fab_share);
    fabShare.setOnClickListener(v -> {
        try {
            UiUtils.shareFile(activity, logFile, activity.getString(R.string.share_log_file));
        } catch (Throwable e) {
            provider.get(ILogger.class).e(TAG, activity.getString(R.string.error_sharing_log_file), e);
        }
    });
    BehaviorSubject<File> subject = BehaviorSubject.createDefault(logFile);
    fabClear.setOnClickListener(view1 -> {
        fileHelper.clearLogFile();
        provider.get(ILogger.class).i(TAG, activity.getString(R.string.log_file_deleted));
        provider.get(Handler.class).post(() -> subject.onNext(logFile));
    });
    mSvProvider.get(RxDisposer.class).add("readLogFile", subject.observeOn(Schedulers.from(BaseApplication.of(activity).getProvider().get(ExecutorService.class))).map(file -> {
        if (!file.exists()) {
            return "";
        } else {
            StringBuilder stringBuilder = new StringBuilder();
            BufferedReader bufferedReader = new BufferedReader(new FileReader(file));
            char[] buff = new char[2048];
            int b = bufferedReader.read(buff);
            while (b != -1) {
                stringBuilder.append(buff);
                b = bufferedReader.read(buff);
            }
            return stringBuilder.toString();
        }
    }).observeOn(AndroidSchedulers.mainThread()).subscribe(s -> {
        progressBar.setVisibility(View.GONE);
        textView.setText(s);
        if (s.isEmpty()) {
            noRecord.setVisibility(View.VISIBLE);
            scrollView.setVisibility(View.GONE);
            fabShare.setVisibility(View.GONE);
            fabClear.setVisibility(View.GONE);
        } else {
            noRecord.setVisibility(View.GONE);
            scrollView.setVisibility(View.VISIBLE);
            scrollView.post(() -> scrollView.fullScroll(View.FOCUS_DOWN));
            fabShare.setVisibility(View.VISIBLE);
            fabClear.setVisibility(View.VISIBLE);
        }
    }));
    return view;
}
Also used : FileHelper(m.co.rh.id.a_medic_log.base.provider.FileHelper) ProgressBar(android.widget.ProgressBar) ILogger(m.co.rh.id.alogger.ILogger) BehaviorSubject(io.reactivex.rxjava3.subjects.BehaviorSubject) AppBarSV(m.co.rh.id.a_medic_log.app.ui.component.AppBarSV) BaseApplication(m.co.rh.id.a_medic_log.base.BaseApplication) Schedulers(io.reactivex.rxjava3.schedulers.Schedulers) NavInject(m.co.rh.id.anavigator.annotation.NavInject) UiUtils(m.co.rh.id.a_medic_log.app.util.UiUtils) Handler(android.os.Handler) FloatingActionButton(com.google.android.material.floatingactionbutton.FloatingActionButton) View(android.view.View) RxProviderModule(m.co.rh.id.a_medic_log.app.provider.RxProviderModule) ExecutorService(java.util.concurrent.ExecutorService) StatefulView(m.co.rh.id.anavigator.StatefulView) Provider(m.co.rh.id.aprovider.Provider) ViewGroup(android.view.ViewGroup) File(java.io.File) AndroidSchedulers(io.reactivex.rxjava3.android.schedulers.AndroidSchedulers) TextView(android.widget.TextView) ScrollView(android.widget.ScrollView) RxDisposer(m.co.rh.id.a_medic_log.app.rx.RxDisposer) R(m.co.rh.id.a_medic_log.R) BufferedReader(java.io.BufferedReader) FileReader(java.io.FileReader) Activity(android.app.Activity) ViewGroup(android.view.ViewGroup) Handler(android.os.Handler) View(android.view.View) StatefulView(m.co.rh.id.anavigator.StatefulView) TextView(android.widget.TextView) ScrollView(android.widget.ScrollView) RxDisposer(m.co.rh.id.a_medic_log.app.rx.RxDisposer) Provider(m.co.rh.id.aprovider.Provider) FileHelper(m.co.rh.id.a_medic_log.base.provider.FileHelper) ScrollView(android.widget.ScrollView) RxProviderModule(m.co.rh.id.a_medic_log.app.provider.RxProviderModule) BufferedReader(java.io.BufferedReader) FloatingActionButton(com.google.android.material.floatingactionbutton.FloatingActionButton) TextView(android.widget.TextView) ILogger(m.co.rh.id.alogger.ILogger) FileReader(java.io.FileReader) ProgressBar(android.widget.ProgressBar) File(java.io.File)

Example 2 with RxProviderModule

use of m.co.rh.id.a_medic_log.app.provider.RxProviderModule in project a-medic-log by rh-id.

the class MainActivity method onCreate.

@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
    mActivityProvider = Provider.createNestedProvider("ActivityProvider", BaseApplication.of(this).getProvider(), getApplicationContext(), new RxProviderModule());
    mAppNotificationHandler = mActivityProvider.get(AppNotificationHandler.class);
    mRebuildUi = BehaviorSubject.create();
    // rebuild UI is expensive and error prone, avoid spam rebuild (especially due to day and night mode)
    mActivityProvider.get(RxDisposer.class).add("rebuildUI", mRebuildUi.debounce(100, TimeUnit.MILLISECONDS).observeOn(AndroidSchedulers.mainThread()).subscribe(aBoolean -> {
        if (aBoolean) {
            BaseApplication.of(this).getNavigator(this).reBuildAllRoute();
            // Switching to night mode didn't update window background for some reason?
            // seemed to occur on android 8 and below
            getWindow().setBackgroundDrawableResource(R.color.daynight_white_black);
        }
    }));
    getOnBackPressedDispatcher().addCallback(this, new OnBackPressedCallback(true) {

        @Override
        public void handleOnBackPressed() {
            BaseApplication.of(MainActivity.this).getNavigator(MainActivity.this).onBackPressed();
        }
    });
    mAppNotificationHandler.processNotification(getIntent());
    super.onCreate(savedInstanceState);
}
Also used : Bundle(android.os.Bundle) Provider(m.co.rh.id.aprovider.Provider) NonNull(androidx.annotation.NonNull) Intent(android.content.Intent) BehaviorSubject(io.reactivex.rxjava3.subjects.BehaviorSubject) AppCompatActivity(androidx.appcompat.app.AppCompatActivity) BaseApplication(m.co.rh.id.a_medic_log.base.BaseApplication) TimeUnit(java.util.concurrent.TimeUnit) AndroidSchedulers(io.reactivex.rxjava3.android.schedulers.AndroidSchedulers) AppNotificationHandler(m.co.rh.id.a_medic_log.app.provider.component.AppNotificationHandler) OnBackPressedCallback(androidx.activity.OnBackPressedCallback) Nullable(androidx.annotation.Nullable) RxDisposer(m.co.rh.id.a_medic_log.app.rx.RxDisposer) Configuration(android.content.res.Configuration) R(m.co.rh.id.a_medic_log.R) RxProviderModule(m.co.rh.id.a_medic_log.app.provider.RxProviderModule) OnBackPressedCallback(androidx.activity.OnBackPressedCallback) RxProviderModule(m.co.rh.id.a_medic_log.app.provider.RxProviderModule) AppNotificationHandler(m.co.rh.id.a_medic_log.app.provider.component.AppNotificationHandler) RxDisposer(m.co.rh.id.a_medic_log.app.rx.RxDisposer)

Aggregations

AndroidSchedulers (io.reactivex.rxjava3.android.schedulers.AndroidSchedulers)2 BehaviorSubject (io.reactivex.rxjava3.subjects.BehaviorSubject)2 R (m.co.rh.id.a_medic_log.R)2 RxProviderModule (m.co.rh.id.a_medic_log.app.provider.RxProviderModule)2 RxDisposer (m.co.rh.id.a_medic_log.app.rx.RxDisposer)2 BaseApplication (m.co.rh.id.a_medic_log.base.BaseApplication)2 Provider (m.co.rh.id.aprovider.Provider)2 Activity (android.app.Activity)1 Intent (android.content.Intent)1 Configuration (android.content.res.Configuration)1 Bundle (android.os.Bundle)1 Handler (android.os.Handler)1 View (android.view.View)1 ViewGroup (android.view.ViewGroup)1 ProgressBar (android.widget.ProgressBar)1 ScrollView (android.widget.ScrollView)1 TextView (android.widget.TextView)1 OnBackPressedCallback (androidx.activity.OnBackPressedCallback)1 NonNull (androidx.annotation.NonNull)1 Nullable (androidx.annotation.Nullable)1