From 4a571d9326c3ce7dfed890bbde7089619bd6c5a2 Mon Sep 17 00:00:00 2001 From: Page Asgardius Date: Thu, 6 Oct 2022 07:51:20 -0700 Subject: [PATCH 1/7] first step --- .../page/s3manager/MainActivity.java | 91 ++++++++++++++++--- .../asgardius/page/s3manager/MyDbHelper.java | 10 +- 2 files changed, 86 insertions(+), 15 deletions(-) diff --git a/app/src/main/java/asgardius/page/s3manager/MainActivity.java b/app/src/main/java/asgardius/page/s3manager/MainActivity.java index f2fe71f..4cebd8d 100644 --- a/app/src/main/java/asgardius/page/s3manager/MainActivity.java +++ b/app/src/main/java/asgardius/page/s3manager/MainActivity.java @@ -27,6 +27,7 @@ public class MainActivity extends AppCompatActivity { ArrayList Name; ArrayList Img; MyDbHelper dbHelper; + int videocache, videotime; @Override protected void onCreate(Bundle savedInstanceState) { @@ -40,6 +41,73 @@ public class MainActivity extends AppCompatActivity { recyclerView.setLayoutManager(linearLayoutManager); dbHelper = new MyDbHelper(this); + Thread getprefs = new Thread(new Runnable() { + + @Override + public void run() { + try { + //Your code goes here + // Database Queries + try { + db = dbHelper.getWritableDatabase(); + String query = "SELECT value FROM preferences where setting='videocache'"; + Cursor cursor = db.rawQuery(query,null); + while (cursor.moveToNext()){ + videocache = (Integer.parseInt(cursor.getString(0))); + } + db.close(); + } catch (Exception e) { + try { + db = dbHelper.getWritableDatabase(); + db.execSQL("INSERT INTO preferences VALUES ('videocache', '300')"); + videocache = 300; + db.close(); + } catch (Exception f) { + db = dbHelper.getWritableDatabase(); + db.execSQL("CREATE TABLE IF NOT EXISTS preferences(setting text UNIQUE, value text)"); + db.execSQL("INSERT INTO preferences VALUES ('videocache', '300')"); + db.execSQL("INSERT INTO preferences VALUES ('videotime', '3')"); + videocache = 300; + //videotime = 3; + db.close(); + } + } + try { + db = dbHelper.getWritableDatabase(); + String query = "SELECT value FROM preferences where setting='videotime'"; + Cursor cursor = db.rawQuery(query,null); + while (cursor.moveToNext()){ + videotime = (Integer.parseInt(cursor.getString(0))); + } + db.close(); + } catch (Exception e) { + try { + db = dbHelper.getWritableDatabase(); + db.execSQL("INSERT INTO preferences VALUES ('videotime', '3')"); + videotime = 3; + db.close(); + } catch (Exception f) { + db = dbHelper.getWritableDatabase(); + db.execSQL("CREATE TABLE IF NOT EXISTS preferences(setting text UNIQUE, value text)"); + db.close(); + } + } + System.out.println("videocache " + videocache); + System.out.println("videotime " + videotime); + } catch (Exception e) { + e.printStackTrace(); + runOnUiThread(new Runnable() { + + @Override + public void run() { + Toast.makeText(getApplicationContext(),getResources().getString(R.string.broken_database), Toast.LENGTH_SHORT).show(); + } + }); + //Toast.makeText(getApplicationContext(),getResources().getString(R.string.media_list_fail), Toast.LENGTH_SHORT).show(); + finish(); + } + } + }); Thread listaccount = new Thread(new Runnable() { @Override @@ -47,20 +115,17 @@ public class MainActivity extends AppCompatActivity { try { //Your code goes here db = dbHelper.getWritableDatabase(); - if (db != null) { - // Database Queries - Name = new ArrayList(); - Img = new ArrayList(); - String query = "SELECT id FROM account"; - Cursor cursor = db.rawQuery(query,null); - while (cursor.moveToNext()){ - Name.add(cursor.getString(0)); - Img.add(R.drawable.account); - } - db.close(); - } else { - Toast.makeText(getApplicationContext(),getResources().getString(R.string.broken_database), Toast.LENGTH_SHORT).show(); + // Database Queries + Name = new ArrayList(); + Img = new ArrayList(); + String query = "SELECT id FROM account"; + Cursor cursor = db.rawQuery(query,null); + while (cursor.moveToNext()){ + Name.add(cursor.getString(0)); + Img.add(R.drawable.account); } + db.close(); + getprefs.start(); runOnUiThread(new Runnable() { @Override diff --git a/app/src/main/java/asgardius/page/s3manager/MyDbHelper.java b/app/src/main/java/asgardius/page/s3manager/MyDbHelper.java index c215b7a..e2f9928 100644 --- a/app/src/main/java/asgardius/page/s3manager/MyDbHelper.java +++ b/app/src/main/java/asgardius/page/s3manager/MyDbHelper.java @@ -5,7 +5,10 @@ import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; public class MyDbHelper extends SQLiteOpenHelper { - private static final String atcreate = "CREATE TABLE IF NOT EXISTS account(id text UNIQUE, endpoint text, username text, password text, region text, pdfendpoint text)"; + private static final String usertable = "CREATE TABLE IF NOT EXISTS account(id text UNIQUE, endpoint text, username text, password text, region text, pdfendpoint text)"; + private static final String preftable = "CREATE TABLE IF NOT EXISTS preferences(setting text UNIQUE, value text)"; + private static final String setvideocache = "INSERT INTO preferences VALUES ('videocache', '300')"; + private static final String setvideotime = "INSERT INTO preferences VALUES ('videotime', '3')"; //private static final String upgrade = "ALTER TABLE account add column pdfendpoint text"; private static final int DATABASE_VERSION = 1; private static final String dbname = "accounts.sqlite3"; @@ -15,7 +18,10 @@ public class MyDbHelper extends SQLiteOpenHelper { } @Override public void onCreate(SQLiteDatabase db) { - db.execSQL(atcreate); + db.execSQL(usertable); + db.execSQL(preftable); + db.execSQL(setvideocache); + db.execSQL(setvideotime); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { From 7bc22c5c7cdb14cc1aaf82e66bf1bec625174de3 Mon Sep 17 00:00:00 2001 From: Page Asgardius Date: Thu, 6 Oct 2022 08:01:48 -0700 Subject: [PATCH 2/7] settings screen template --- app/src/main/AndroidManifest.xml | 9 ++ .../asgardius/page/s3manager/Settings.java | 27 ++++++ app/src/main/res/layout/activity_settings.xml | 16 ++++ app/src/main/res/layout/content_settings.xml | 27 ++++++ app/src/main/res/menu/menu_settings.xml | 10 ++ app/src/main/res/values-land/dimens.xml | 4 + app/src/main/res/values-w1240dp/dimens.xml | 3 + app/src/main/res/values-w600dp/dimens.xml | 4 + app/src/main/res/values/dimens.xml | 5 + app/src/main/res/values/strings.xml | 91 +++++++++++++++++++ app/src/main/res/values/themes.xml | 9 ++ 11 files changed, 205 insertions(+) create mode 100644 app/src/main/java/asgardius/page/s3manager/Settings.java create mode 100644 app/src/main/res/layout/activity_settings.xml create mode 100644 app/src/main/res/layout/content_settings.xml create mode 100644 app/src/main/res/menu/menu_settings.xml create mode 100644 app/src/main/res/values-land/dimens.xml create mode 100644 app/src/main/res/values-w1240dp/dimens.xml create mode 100644 app/src/main/res/values-w600dp/dimens.xml create mode 100644 app/src/main/res/values/dimens.xml diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 1a20301..7f59e8e 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -19,6 +19,15 @@ android:supportsRtl="true" android:theme="@style/Theme.AsgardiusS3Manager" tools:targetApi="31"> + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/content_settings.xml b/app/src/main/res/layout/content_settings.xml new file mode 100644 index 0000000..8edbb86 --- /dev/null +++ b/app/src/main/res/layout/content_settings.xml @@ -0,0 +1,27 @@ + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/menu/menu_settings.xml b/app/src/main/res/menu/menu_settings.xml new file mode 100644 index 0000000..c926142 --- /dev/null +++ b/app/src/main/res/menu/menu_settings.xml @@ -0,0 +1,10 @@ + + + \ No newline at end of file diff --git a/app/src/main/res/values-land/dimens.xml b/app/src/main/res/values-land/dimens.xml new file mode 100644 index 0000000..96d25a4 --- /dev/null +++ b/app/src/main/res/values-land/dimens.xml @@ -0,0 +1,4 @@ + + 48dp + 48dp + \ No newline at end of file diff --git a/app/src/main/res/values-w1240dp/dimens.xml b/app/src/main/res/values-w1240dp/dimens.xml new file mode 100644 index 0000000..d73f4a3 --- /dev/null +++ b/app/src/main/res/values-w1240dp/dimens.xml @@ -0,0 +1,3 @@ + + 200dp + \ No newline at end of file diff --git a/app/src/main/res/values-w600dp/dimens.xml b/app/src/main/res/values-w600dp/dimens.xml new file mode 100644 index 0000000..96d25a4 --- /dev/null +++ b/app/src/main/res/values-w600dp/dimens.xml @@ -0,0 +1,4 @@ + + 48dp + 48dp + \ No newline at end of file diff --git a/app/src/main/res/values/dimens.xml b/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000..89ef465 --- /dev/null +++ b/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + 180dp + 16dp + 16dp + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 995cdd6..bf7b960 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -89,4 +89,95 @@ About this app Dummy Button DUMMY\nCONTENT + Settings + + "Material is the metaphor.\n\n" + + "A material metaphor is the unifying theory of a rationalized space and a system of motion." + "The material is grounded in tactile reality, inspired by the study of paper and ink, yet " + "technologically advanced and open to imagination and magic.\n" + "Surfaces and edges of the material provide visual cues that are grounded in reality. The " + "use of familiar tactile attributes helps users quickly understand affordances. Yet the " + "flexibility of the material creates new affordances that supercede those in the physical " + "world, without breaking the rules of physics.\n" + "The fundamentals of light, surface, and movement are key to conveying how objects move, " + "interact, and exist in space and in relation to each other. Realistic lighting shows " + "seams, divides space, and indicates moving parts.\n\n" + + "Bold, graphic, intentional.\n\n" + + "The foundational elements of print based design typography, grids, space, scale, color, " + "and use of imagery guide visual treatments. These elements do far more than please the " + "eye. They create hierarchy, meaning, and focus. Deliberate color choices, edge to edge " + "imagery, large scale typography, and intentional white space create a bold and graphic " + "interface that immerse the user in the experience.\n" + "An emphasis on user actions makes core functionality immediately apparent and provides " + "waypoints for the user.\n\n" + + "Motion provides meaning.\n\n" + + "Motion respects and reinforces the user as the prime mover. Primary user actions are " + "inflection points that initiate motion, transforming the whole design.\n" + "All action takes place in a single environment. Objects are presented to the user without " + "breaking the continuity of experience even as they transform and reorganize.\n" + "Motion is meaningful and appropriate, serving to focus attention and maintain continuity. " + "Feedback is subtle yet clear. Transitions are efficient yet coherent.\n\n" + + "3D world.\n\n" + + "The material environment is a 3D space, which means all objects have x, y, and z " + "dimensions. The z-axis is perpendicularly aligned to the plane of the display, with the " + "positive z-axis extending towards the viewer. Every sheet of material occupies a single " + "position along the z-axis and has a standard 1dp thickness.\n" + "On the web, the z-axis is used for layering and not for perspective. The 3D world is " + "emulated by manipulating the y-axis.\n\n" + + "Light and shadow.\n\n" + + "Within the material environment, virtual lights illuminate the scene. Key lights create " + "directional shadows, while ambient light creates soft shadows from all angles.\n" + "Shadows in the material environment are cast by these two light sources. In Android " + "development, shadows occur when light sources are blocked by sheets of material at " + "various positions along the z-axis. On the web, shadows are depicted by manipulating the " + "y-axis only. The following example shows the card with a height of 6dp.\n\n" + + "Resting elevation.\n\n" + + "All material objects, regardless of size, have a resting elevation, or default elevation " + "that does not change. If an object changes elevation, it should return to its resting " + "elevation as soon as possible.\n\n" + + "Component elevations.\n\n" + + "The resting elevation for a component type is consistent across apps (e.g., FAB elevation " + "does not vary from 6dp in one app to 16dp in another app).\n" + "Components may have different resting elevations across platforms, depending on the depth " + "of the environment (e.g., TV has a greater depth than mobile or desktop).\n\n" + + "Responsive elevation and dynamic elevation offsets.\n\n" + + "Some component types have responsive elevation, meaning they change elevation in response " + "to user input (e.g., normal, focused, and pressed) or system events. These elevation " + "changes are consistently implemented using dynamic elevation offsets.\n" + "Dynamic elevation offsets are the goal elevation that a component moves towards, relative " + "to the component’s resting state. They ensure that elevation changes are consistent " + "across actions and component types. For example, all components that lift on press have " + "the same elevation change relative to their resting elevation.\n" + "Once the input event is completed or cancelled, the component will return to its resting " + "elevation.\n\n" + + "Avoiding elevation interference.\n\n" + + "Components with responsive elevations may encounter other components as they move between " + "their resting elevations and dynamic elevation offsets. Because material cannot pass " + "through other material, components avoid interfering with one another any number of ways, " + "whether on a per component basis or using the entire app layout.\n" + "On a component level, components can move or be removed before they cause interference. " + "For example, a floating action button (FAB) can disappear or move off screen before a " + "user picks up a card, or it can move if a snackbar appears.\n" + "On the layout level, design your app layout to minimize opportunities for interference. " + "For example, position the FAB to one side of stream of a cards so the FAB won’t interfere " + "when a user tries to pick up one of cards.\n\n" + + Settings \ No newline at end of file diff --git a/app/src/main/res/values/themes.xml b/app/src/main/res/values/themes.xml index 1a59a11..a689e45 100644 --- a/app/src/main/res/values/themes.xml +++ b/app/src/main/res/values/themes.xml @@ -26,4 +26,13 @@ @color/light_blue_600 @color/light_blue_A200 + + + +