Move commands to uhabits-core

pull/87/merge
Alinson S. Xavier 8 years ago
parent acd653db70
commit 370e7343d7

@ -90,6 +90,9 @@ public class ListHabitsScreen extends BaseScreen
@NonNull @NonNull
private Preferences prefs; private Preferences prefs;
@NonNull
private final CommandParser commandParser;
@Inject @Inject
public ListHabitsScreen(@NonNull BaseActivity activity, public ListHabitsScreen(@NonNull BaseActivity activity,
@NonNull CommandRunner commandRunner, @NonNull CommandRunner commandRunner,
@ -99,9 +102,11 @@ public class ListHabitsScreen extends BaseScreen
@NonNull ConfirmDeleteDialogFactory confirmDeleteDialogFactory, @NonNull ConfirmDeleteDialogFactory confirmDeleteDialogFactory,
@NonNull ColorPickerDialogFactory colorPickerFactory, @NonNull ColorPickerDialogFactory colorPickerFactory,
@NonNull EditHabitDialogFactory editHabitDialogFactory, @NonNull EditHabitDialogFactory editHabitDialogFactory,
@NonNull Preferences prefs) @NonNull Preferences prefs,
@NonNull CommandParser commandParser)
{ {
super(activity); super(activity);
this.commandParser = commandParser;
setRootView(rootView); setRootView(rootView);
this.prefs = prefs; this.prefs = prefs;
this.colorPickerFactory = colorPickerFactory; this.colorPickerFactory = colorPickerFactory;
@ -122,7 +127,7 @@ public class ListHabitsScreen extends BaseScreen
@Nullable Long refreshKey) @Nullable Long refreshKey)
{ {
if(command.isRemote()) return; if(command.isRemote()) return;
showMessage(command.getExecuteStringId()); showMessage(commandParser.getExecuteString(command));
} }
public void onDettached() public void onDettached()

@ -23,6 +23,7 @@ import android.support.annotation.*;
import com.google.gson.*; import com.google.gson.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
import org.json.*; import org.json.*;
@ -42,6 +43,30 @@ public class CommandParser
this.modelFactory = modelFactory; this.modelFactory = modelFactory;
} }
@StringRes
public Integer getExecuteString(@NonNull Command command)
{
if(command instanceof ArchiveHabitsCommand)
return R.string.toast_habit_archived;
if(command instanceof ChangeHabitColorCommand)
return R.string.toast_habit_changed;
if(command instanceof CreateHabitCommand)
return R.string.toast_habit_created;
if(command instanceof DeleteHabitsCommand)
return R.string.toast_habit_deleted;
if(command instanceof EditHabitCommand)
return R.string.toast_habit_changed;
if(command instanceof UnarchiveHabitsCommand)
return R.string.toast_habit_unarchived;
return null;
}
@NonNull @NonNull
public Command parse(@NonNull JSONObject json) throws JSONException public Command parse(@NonNull JSONObject json) throws JSONException
{ {

@ -108,13 +108,25 @@ public class SyncManager implements CommandRunner.Listener
connect(context, serverURL); connect(context, serverURL);
} }
private JSONObject toJSONObject(String json)
{
try
{
return new JSONObject(json);
}
catch (JSONException e)
{
throw new RuntimeException(e);
}
}
@Override @Override
public void onCommandExecuted(@NonNull Command command, public void onCommandExecuted(@NonNull Command command,
@Nullable Long refreshKey) @Nullable Long refreshKey)
{ {
if (command.isRemote()) return; if (command.isRemote()) return;
JSONObject msg = command.toJson(); JSONObject msg = toJSONObject(command.toJson());
Long now = new Date().getTime(); Long now = new Date().getTime();
Event e = new Event(command.getId(), now, msg.toString()); Event e = new Event(command.getId(), now, msg.toString());
e.save(); e.save();

@ -30,9 +30,7 @@ import org.isoron.uhabits.models.sqlite.records.*;
import org.isoron.uhabits.sync.*; import org.isoron.uhabits.sync.*;
import java.io.*; import java.io.*;
import java.math.*;
import java.text.*; import java.text.*;
import java.util.*;
public abstract class DatabaseUtils public abstract class DatabaseUtils
{ {
@ -70,11 +68,6 @@ public abstract class DatabaseUtils
return databaseFilename; return databaseFilename;
} }
public static String getRandomId()
{
return new BigInteger(260, new Random()).toString(32).substring(0, 32);
}
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public static void initializeActiveAndroid(Context context) public static void initializeActiveAndroid(Context context)
{ {

@ -17,7 +17,7 @@
* with this program. If not, see <http://www.gnu.org/licenses/>. * with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
package org.isoron.uhabits.activities; package org.isoron.androidbase.activities;
import android.content.*; import android.content.*;
import android.os.*; import android.os.*;
@ -27,8 +27,8 @@ import android.support.v7.widget.Toolbar;
import android.view.*; import android.view.*;
import android.widget.*; import android.widget.*;
import org.isoron.androidbase.activities.*;
import org.isoron.uhabits.*; import org.isoron.uhabits.*;
import org.isoron.uhabits.activities.*;
import org.isoron.uhabits.activities.common.dialogs.*; import org.isoron.uhabits.activities.common.dialogs.*;
import org.junit.*; import org.junit.*;
import org.junit.runner.*; import org.junit.runner.*;

@ -17,7 +17,7 @@
* with this program. If not, see <http://www.gnu.org/licenses/>. * with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
package org.isoron.uhabits.activities; package org.isoron.androidbase.activities;
import android.content.*; import android.content.*;
import android.support.annotation.*; import android.support.annotation.*;
@ -25,7 +25,6 @@ import android.support.v7.view.ActionMode;
import android.support.v7.widget.*; import android.support.v7.widget.*;
import android.view.*; import android.view.*;
import org.isoron.androidbase.activities.*;
import org.isoron.uhabits.*; import org.isoron.uhabits.*;
import org.junit.*; import org.junit.*;
import org.junit.runner.*; import org.junit.runner.*;
@ -38,6 +37,7 @@ import static android.view.View.*;
import static junit.framework.Assert.assertNotNull; import static junit.framework.Assert.assertNotNull;
import static org.hamcrest.core.IsEqual.*; import static org.hamcrest.core.IsEqual.*;
import static org.junit.Assert.*; import static org.junit.Assert.*;
import static org.junit.Assert.assertTrue;
import static org.mockito.Matchers.any; import static org.mockito.Matchers.any;
import static org.mockito.Mockito.*; import static org.mockito.Mockito.*;
import static org.robolectric.Robolectric.*; import static org.robolectric.Robolectric.*;

@ -71,6 +71,8 @@ public class ListHabitsScreenTest extends BaseUnitTest
private Preferences prefs; private Preferences prefs;
private CommandParser commandParser;
@Before @Before
@Override @Override
public void setUp() public void setUp()
@ -86,10 +88,11 @@ public class ListHabitsScreenTest extends BaseUnitTest
colorPickerDialogFactory = mock(ColorPickerDialogFactory.class); colorPickerDialogFactory = mock(ColorPickerDialogFactory.class);
dialogFactory = mock(EditHabitDialogFactory.class); dialogFactory = mock(EditHabitDialogFactory.class);
prefs = mock(Preferences.class); prefs = mock(Preferences.class);
commandParser = mock(CommandParser.class);
screen = spy(new ListHabitsScreen(activity, commandRunner, rootView, screen = spy(new ListHabitsScreen(activity, commandRunner, rootView,
intentFactory, themeSwitcher, confirmDeleteDialogFactory, intentFactory, themeSwitcher, confirmDeleteDialogFactory,
colorPickerDialogFactory, dialogFactory, prefs)); colorPickerDialogFactory, dialogFactory, prefs, commandParser));
doNothing().when(screen).showMessage(anyInt()); doNothing().when(screen).showMessage(anyInt());
@ -122,7 +125,8 @@ public class ListHabitsScreenTest extends BaseUnitTest
public void testOnCommand() public void testOnCommand()
{ {
Command c = mock(Command.class); Command c = mock(Command.class);
when(c.getExecuteStringId()).thenReturn(R.string.toast_habit_deleted); when(commandParser.getExecuteString(c)).thenReturn(
R.string.toast_habit_deleted);
screen.onCommandExecuted(c, null); screen.onCommandExecuted(c, null);
verify(screen).showMessage(R.string.toast_habit_deleted); verify(screen).showMessage(R.string.toast_habit_deleted);
} }

@ -26,6 +26,7 @@ dependencies {
implementation 'com.google.auto.factory:auto-factory:1.0-beta3' implementation 'com.google.auto.factory:auto-factory:1.0-beta3'
implementation 'com.google.code.findbugs:jsr305:3.0.2' implementation 'com.google.code.findbugs:jsr305:3.0.2'
implementation 'org.apache.commons:commons-lang3:3.5' implementation 'org.apache.commons:commons-lang3:3.5'
implementation 'com.google.code.gson:gson:2.7'
implementation ('com.opencsv:opencsv:3.9') { implementation ('com.opencsv:opencsv:3.9') {
exclude group: 'commons-logging', module: 'commons-logging' exclude group: 'commons-logging', module: 'commons-logging'

@ -21,7 +21,6 @@ package org.isoron.uhabits.commands;
import android.support.annotation.*; import android.support.annotation.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
import java.util.*; import java.util.*;
@ -50,18 +49,6 @@ public class ArchiveHabitsCommand extends Command
habitList.update(selected); habitList.update(selected);
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_archived;
}
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_unarchived;
}
@Override @Override
public void undo() public void undo()
{ {

@ -21,7 +21,6 @@ package org.isoron.uhabits.commands;
import android.support.annotation.*; import android.support.annotation.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
import java.util.*; import java.util.*;
@ -61,18 +60,6 @@ public class ChangeHabitColorCommand extends Command
habitList.update(selected); habitList.update(selected);
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_changed;
}
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_changed;
}
@NonNull @NonNull
@Override @Override
public Record toRecord() public Record toRecord()

@ -24,7 +24,6 @@ import android.support.annotation.*;
import com.google.gson.*; import com.google.gson.*;
import org.isoron.uhabits.utils.*; import org.isoron.uhabits.utils.*;
import org.json.*;
/** /**
* A Command represents a desired set of changes that should be performed on the * A Command represents a desired set of changes that should be performed on the
@ -43,7 +42,7 @@ public abstract class Command
public Command() public Command()
{ {
id = DatabaseUtils.getRandomId(); id = StringUtils.getRandomId();
isRemote = false; isRemote = false;
} }
@ -55,11 +54,6 @@ public abstract class Command
public abstract void execute(); public abstract void execute();
public Integer getExecuteStringId()
{
return null;
}
public String getId() public String getId()
{ {
return id; return id;
@ -70,11 +64,6 @@ public abstract class Command
this.id = id; this.id = id;
} }
public Integer getUndoStringId()
{
return null;
}
public boolean isRemote() public boolean isRemote()
{ {
return isRemote; return isRemote;
@ -86,17 +75,9 @@ public abstract class Command
} }
@NonNull @NonNull
public JSONObject toJson() public String toJson()
{
try
{ {
String json = new GsonBuilder().create().toJson(toRecord()); return new GsonBuilder().create().toJson(toRecord());
return new JSONObject(json);
}
catch (JSONException e)
{
throw new RuntimeException(e);
}
} }
@NonNull @NonNull

@ -23,7 +23,6 @@ import android.support.annotation.*;
import com.google.auto.factory.*; import com.google.auto.factory.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
/** /**
@ -62,18 +61,6 @@ public class CreateHabitCommand extends Command
savedId = savedHabit.getId(); savedId = savedHabit.getId();
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_created;
}
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_deleted;
}
@NonNull @NonNull
@Override @Override
public Record toRecord() public Record toRecord()

@ -21,7 +21,6 @@ package org.isoron.uhabits.commands;
import android.support.annotation.*; import android.support.annotation.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
import java.util.*; import java.util.*;
@ -52,23 +51,11 @@ public class DeleteHabitsCommand extends Command
habitList.remove(h); habitList.remove(h);
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_deleted;
}
public List<Habit> getSelected() public List<Habit> getSelected()
{ {
return Collections.unmodifiableList(selected); return Collections.unmodifiableList(selected);
} }
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_restored;
}
@Override @Override
@NonNull @NonNull
public Record toRecord() public Record toRecord()

@ -23,7 +23,6 @@ import android.support.annotation.*;
import com.google.auto.factory.*; import com.google.auto.factory.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
/** /**
@ -77,18 +76,6 @@ public class EditHabitCommand extends Command
copyAttributes(this.modified); copyAttributes(this.modified);
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_changed;
}
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_changed_back;
}
@NonNull @NonNull
@Override @Override
public Record toRecord() public Record toRecord()

@ -21,7 +21,6 @@ package org.isoron.uhabits.commands;
import android.support.annotation.*; import android.support.annotation.*;
import org.isoron.uhabits.*;
import org.isoron.uhabits.models.*; import org.isoron.uhabits.models.*;
import java.util.*; import java.util.*;
@ -51,18 +50,6 @@ public class UnarchiveHabitsCommand extends Command
habitList.update(selected); habitList.update(selected);
} }
@Override
public Integer getExecuteStringId()
{
return R.string.toast_habit_unarchived;
}
@Override
public Integer getUndoStringId()
{
return R.string.toast_habit_archived;
}
@Override @Override
@NonNull @NonNull
public Record toRecord() public Record toRecord()

@ -0,0 +1,31 @@
/*
* Copyright (C) 2017 Álinson Santos Xavier <isoron@gmail.com>
*
* This file is part of Loop Habit Tracker.
*
* Loop Habit Tracker is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by the
* Free Software Foundation, either version 3 of the License, or (at your
* option) any later version.
*
* Loop Habit Tracker is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.isoron.uhabits.utils;
import java.math.*;
import java.util.*;
public class StringUtils
{
public static String getRandomId()
{
return new BigInteger(260, new Random()).toString(32).substring(0, 32);
}
}
Loading…
Cancel
Save