Commit 7789e79d authored by cosmina.dunca's avatar cosmina.dunca

Finished

parents
*.iml
.gradle
/local.properties
/.idea/caches
/.idea/libraries
/.idea/modules.xml
/.idea/workspace.xml
/.idea/navEditor.xml
/.idea/assetWizardSettings.xml
.DS_Store
/build
/captures
.externalNativeBuild
.cxx
local.properties
# Default ignored files
/shelf/
/workspace.xml
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<bytecodeTargetLevel target="11" />
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleMigrationSettings" migrationVersion="1" />
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
<option name="testRunner" value="GRADLE" />
<option name="distributionType" value="DEFAULT_WRAPPED" />
<option name="externalProjectPath" value="$PROJECT_DIR$" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$" />
<option value="$PROJECT_DIR$/app" />
</set>
</option>
</GradleProjectSettings>
</option>
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="Android Studio default JDK" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/build/classes" />
</component>
<component name="ProjectType">
<option name="id" value="Android" />
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="RenderSettings">
<option name="showDecorations" value="true" />
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
</component>
</project>
\ No newline at end of file
/build
\ No newline at end of file
plugins {
id 'com.android.application'
}
android {
namespace 'com.example.assignment'
compileSdk 33
defaultConfig {
applicationId "com.example.assignment"
minSdk 24
targetSdk 33
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.6.1'
implementation 'com.google.android.material:material:1.9.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.5'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
}
\ No newline at end of file
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile
\ No newline at end of file
package com.example.assignment;
import android.content.Context;
import androidx.test.platform.app.InstrumentationRegistry;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import org.junit.Test;
import org.junit.runner.RunWith;
import static org.junit.Assert.*;
/**
* Instrumented test, which will execute on an Android device.
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentedTest {
@Test
public void useAppContext() {
// Context of the app under test.
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
assertEquals("com.example.assignment", appContext.getPackageName());
}
}
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/Theme.Assignment"
tools:targetApi="31">
<activity
android:name=".BookingsActivity"
android:parentActivityName=".TicketsActivity"
android:exported="false" />
<activity
android:name=".Bookings"
android:exported="false" />
<activity
android:name=".TicketsActivity"
android:exported="false"
android:parentActivityName=".DetailActivity" />
<activity
android:name=".DetailActivity"
android:exported="false"
android:parentActivityName=".HomeActivity" />
<activity
android:name=".HomeActivity"
android:exported="false" />
<activity
android:name=".LoginActivity"
android:exported="false" />
<activity
android:name=".MainActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<meta-data
android:name="preloaded_fonts"
android:resource="@array/preloaded_fonts" />
</application>
</manifest>
\ No newline at end of file
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.RecyclerView;
import android.app.AlertDialog;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class BookingsActivity extends AppCompatActivity {
TextView x;
RecyclerView recyclerViewBook;
List<DataBook> dataList;
adapterBookings adapter;
DataBook androidData;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_bookings);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
String title = "", type = "", remove = "";
int nrTick = 0, pos = 0;
x = (TextView) findViewById(R.id.bookTitle);
Bundle bundle = getIntent().getExtras();
if (bundle != null){
title = bundle.getString("TitleTic");
type = bundle.getString("TypeTic");
nrTick = bundle.getInt("NrOfTick");
remove = bundle.getString("Delete");
pos = bundle.getInt("pos");
}
recyclerViewBook = findViewById(R.id.recyclerViewTic);
dataList = new ArrayList<>();
androidData = new DataBook(title, type, nrTick);
dataList.addAll(Arrays.asList(androidData));
adapter = new adapterBookings(this, dataList);
recyclerViewBook.setAdapter(adapter);
if (remove == "Yes"){
dataList.remove(pos);
}
if(dataList.size() == 0)
{
x.setText("No bookings made yet!");
Toast.makeText(getApplicationContext(), "Yes", Toast.LENGTH_LONG).show();
}
//Toast.makeText(getApplicationContext(), String.valueOf(nrTick), Toast.LENGTH_LONG).show();
}
}
\ No newline at end of file
package com.example.assignment;
public class DataBook {
private String bookTitle;
private String bookType;
private int NrOfTick;
public String getBookTitle() { return bookTitle; }
public String getBookType(){ return bookType; }
public int getNrOfTick() {return NrOfTick; }
public DataBook(String bookTitle, String bookType, int nrOfTick) {
this.bookTitle = bookTitle;
this.bookType = bookType;
this.NrOfTick = nrOfTick;
}
}
package com.example.assignment;
public class DataClass {
private String dataTitle;
private int dataDesc;
private String dataDate;
private int dataImage;
private String dataFilter;
public String getDataTitle() {
return dataTitle;
}
public int getDataDesc() {
return dataDesc;
}
public String getDataDate() {
return dataDate;
}
public int getDataImage() {
return dataImage;
}
public String getDataFilter(){
return dataFilter;
}
public DataClass(String dataTitle, int dataDesc, String dataDate, int dataImage, String dataFilter) {
this.dataTitle = dataTitle;
this.dataDesc = dataDesc;
this.dataDate = dataDate;
this.dataImage = dataImage;
this.dataFilter = dataFilter;
}
}
package com.example.assignment;
public class DataTick {
private String ticType;
private int ticQuantity;
private int price;
public String getTicketsType() {
return ticType;
}
public int getTicketsQuantity() {
return ticQuantity;
}
public int getTicketsPrice() {
return price;
}
public DataTick(String ticType, int ticQuantity, int price) {
this.ticType = ticType;
this.ticQuantity = ticQuantity;
this.price = price;
}
}
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
public class DetailActivity extends AppCompatActivity {
TextView detailDesc, detailTitle;
ImageView detailImage;
Button btn;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_detail);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
detailDesc = findViewById(R.id.detailDesc);
detailTitle = findViewById(R.id.detailTitle);
detailImage = findViewById(R.id.detailImage);
Bundle bundle = getIntent().getExtras();
if (bundle != null){
detailDesc.setText(bundle.getInt("Desc"));
detailImage.setImageResource(bundle.getInt("Image"));
detailTitle.setText(bundle.getString("Title"));
}
btn = findViewById(R.id.ticketsBtn);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(DetailActivity.this, TicketsActivity.class);
String x = detailTitle.getText().toString();
intent.putExtra("TitleTic", x);
startActivity(intent);
}
});
}
}
\ No newline at end of file
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.SearchView;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.os.Bundle;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.List;
public class HomeActivity extends AppCompatActivity {
RecyclerView recyclerView;
List<DataClass> dataList;
myAdapter adapter;
DataClass androidData;
SearchView searchView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
recyclerView = findViewById(R.id.recyclerView);
searchView = findViewById(R.id.search);
searchView.clearFocus();
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
return false;
}
@Override
public boolean onQueryTextChange(String newText) {
searchList(newText);
return true;
}
});
GridLayoutManager gridLayoutManager = new GridLayoutManager(HomeActivity.this, 1);
recyclerView.setLayoutManager(gridLayoutManager);
dataList = new ArrayList<>();
androidData = new DataClass("The Merchant of Venice", R.string.merchant, "April 23rd 2023", R.drawable.merchantofvenice, "wheelchair,seated,april,shakespeare");
dataList.add(androidData);
androidData = new DataClass("Hamlet", R.string.hamlet, "May 19th 2023", R.drawable.hamlet, "steps,flashing lights,fake blood,seated,standing,may,shakespeare");
dataList.add(androidData);
androidData = new DataClass("A Midsummer Night's Dream", R.string.midsummer, "June 3rd 2023", R.drawable.midsummer,"wheelchair,flashing lights,on stage,grass,june,shakespeare");
dataList.add(androidData);
androidData = new DataClass("Oedipus the King", R.string.oedipus, "July 28th 2023", R.drawable.oedipus,"wheelchair,seated,standing,july,sophocles");
dataList.add(androidData);
androidData = new DataClass("The Tempest", R.string.tempest, "August 19th 2023", R.drawable.thetempest,"wheelchair,flashing lights,boat,riverbank,august,shakespeare");
dataList.add(androidData);
androidData = new DataClass("Antigone", R.string.antigone, "September 20th 2023", R.drawable.antigone,"steps,standing,inner circle,outer circle,september,sophocles");
dataList.add(androidData);
adapter = new myAdapter(HomeActivity.this, dataList);
recyclerView.setAdapter(adapter);
}
private void searchList(String text){
List<DataClass> dataSearchList = new ArrayList<>();
for (DataClass data : dataList){
String sFilter = data.getDataFilter().toLowerCase();
String sTitle = data.getDataTitle().toLowerCase();
if (sFilter.contains(text.toLowerCase()) || sTitle.contains(text.toLowerCase())) {
dataSearchList.add(data);
}
}
if (dataSearchList.isEmpty()){
Toast.makeText(this, "Not Found", Toast.LENGTH_SHORT).show();
} else {
adapter.setSearchList(dataSearchList);
}
}
}
\ No newline at end of file
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.widget.Button;
import android.widget.EdgeEffect;
import android.widget.EditText;
import android.widget.Toast;
public class LoginActivity extends AppCompatActivity {
EditText username, password;
Button signin, signup;
myDBHelper DB;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
username = findViewById(R.id.usernameLog);
password = findViewById(R.id.passwordLog);
signin = findViewById(R.id.signInLog);
signup = findViewById(R.id.signUpLog);
DB = new myDBHelper(this);
signin.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String user = username.getText().toString();
String pass = password.getText().toString();
if (TextUtils.isEmpty(user) || TextUtils.isEmpty(pass))
Toast.makeText(LoginActivity.this, "All fields are required!", Toast.LENGTH_SHORT).show();
else {
Boolean checkuserpass = DB.checkUsernamePassword(user, pass);
if (checkuserpass == true) {
Toast.makeText(LoginActivity.this, "Successful login!", Toast.LENGTH_SHORT).show();
Intent intent = new Intent(getApplicationContext(), HomeActivity.class);
startActivity(intent);
} else {
if(DB.checkUserName(user) == false)
Toast.makeText(LoginActivity.this, "User doesn't exist. Create an account!", Toast.LENGTH_SHORT).show();
else
Toast.makeText(LoginActivity.this, "Login failed. Try password again.", Toast.LENGTH_SHORT).show();
}
}
}
});
signup.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(getApplicationContext(), MainActivity.class);
startActivity(intent);
}
});
}
}
\ No newline at end of file
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
// variables of EditText and Button to be used later:
EditText username, password, name, surname, rePassword;
Button signUp, signIn;
myDBHelper DB; // initialising the database's type (myDBHelper)
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// give the variables the content of each EditText and Button function using the IDs:
username = findViewById(R.id.username);
password = findViewById(R.id.password);
name = findViewById(R.id.firstname);
surname = findViewById(R.id.surname);
rePassword = findViewById(R.id.repass);
signUp = findViewById(R.id.signup);
signIn = findViewById(R.id.signin);
DB = new myDBHelper(this); // creating the database
signUp.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// create variables with the contents of each EditText
String user = username.getText().toString();
String firstname = name.getText().toString();
String surN = surname.getText().toString();
String pass = password.getText().toString();
String repass = rePassword.getText().toString();
// check to see if and of the EditText fields are empty:
if (TextUtils.isEmpty(user) || TextUtils.isEmpty(firstname) ||
TextUtils.isEmpty(surN) || TextUtils.isEmpty(pass) || TextUtils.isEmpty(repass))
Toast.makeText(MainActivity.this, "All fields are required!", Toast.LENGTH_SHORT).show();
else {
// check if both passwords match
if (pass.equals(repass)) {
Boolean checkuser = DB.checkUserName(user);
if (!checkuser){ // if user doesn't already exist
// insert the new user
Boolean insert = DB.insertUser(user, pass, firstname, surN);
if (insert) { // if insert didn't fail, give positive feedback
// this is not the way too add data into the tickets table because it add these tickets everytime a new account is created (so it's not working if more than one account is created
// however, I don't know how else to use the local database
DB.insertTicket("The Merchant of Venice", "Seated", 17, 17, 8);
DB.insertTicket("Hamlet", "Seated", 8, 8, 8);
DB.insertTicket("Hamlet", "Standing", 12, 12, 7);
Toast.makeText(MainActivity.this, "Registered successfully!", Toast.LENGTH_SHORT).show();
Intent intent = new Intent(getApplicationContext(), HomeActivity.class);
startActivity(intent);
} else {
Toast.makeText(MainActivity.this, "Registration failed.", Toast.LENGTH_SHORT).show();
}
} else {
Toast.makeText(MainActivity.this, "User already exists.", Toast.LENGTH_SHORT).show();
}
} else {
Toast.makeText(MainActivity.this, "Passwords don't match", Toast.LENGTH_SHORT).show();
}
}
}
});
signIn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(getApplicationContext(), LoginActivity.class);
startActivity(intent);
}
});
}
}
\ No newline at end of file
package com.example.assignment;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.net.Uri;
import android.os.Bundle;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class TicketsActivity extends AppCompatActivity {
TextView title;
RecyclerView recyclerViewTic;
List<DataTick> dataList;
adapterTickets adapter;
DataTick androidData;
myDBHelper DB;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_tickets);
getSupportActionBar().setDisplayHomeAsUpEnabled(true); // for returning to previous page
//////////////////////////////////// title - at the top of activity
title = findViewById(R.id.ticTitle);
Bundle bundle = getIntent().getExtras();
if (bundle != null)
{
title.setText(bundle.getString("TitleTic"));
}
////////////////////////////////////
/////////////////////////////////// recycler
recyclerViewTic = findViewById(R.id.recyclerViewTic);
dataList = new ArrayList<>();
DB = new myDBHelper(this);
String line = DB.ticketsType(title.getText().toString());
String types[] = line.split(",");
for (int i = 0; i < types.length; ++i){
androidData = new DataTick("Type of Ticket: " + types[i], 16, 4);
dataList.addAll(Arrays.asList(androidData));
}
adapter = new adapterTickets(this, dataList);
recyclerViewTic.setAdapter(adapter);
adapter.notifyDataSetChanged();
///////////////////////////////////
}
}
\ No newline at end of file
package com.example.assignment;
import android.content.Context;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import java.util.List;
public class adapterBookings extends RecyclerView.Adapter<MyViewHolderBook>{
private Context context;
private List<DataBook> dataList;
public adapterBookings(Context context, List<DataBook> dataList){
this.context = context;
this.dataList = dataList;
}
@NonNull
@Override
public MyViewHolderBook onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_bookings, parent, false);
return new MyViewHolderBook(view);
}
@Override
public void onBindViewHolder(@NonNull MyViewHolderBook holder, int position) {
holder.bookTitle.setText(dataList.get(position).getBookTitle());
holder.bookType.setText(dataList.get(position).getBookType());
holder.bookNr.setText(String.valueOf(dataList.get(position).getNrOfTick()));
holder.cancelBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(context, BookingsActivity.class);
intent.putExtra("Delete", "Yes");
int pos=holder.getAdapterPosition();
intent.putExtra("pos",pos);
context.startActivity(intent);
}
});
}
@Override
public int getItemCount() {
return dataList.size();
}
}
class MyViewHolderBook extends RecyclerView.ViewHolder{
TextView bookTitle, bookType, bookNr;
Button cancelBtn;
public MyViewHolderBook(@NonNull View itemView) {
super(itemView);
bookTitle = itemView.findViewById(R.id.bookTitle);
bookType = itemView.findViewById(R.id.bookType);
bookNr = itemView.findViewById(R.id.nrOfTick);
cancelBtn = itemView.findViewById(R.id.cancelBtn);
}
}
\ No newline at end of file
package com.example.assignment;
import static androidx.core.content.ContextCompat.startActivity;
import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.TextView;
import android.widget.Toast;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import java.util.ArrayList;
import java.util.List;
public class adapterTickets extends RecyclerView.Adapter<MyViewHolderTic>{
private Context context;
private List<DataTick> dataList;
// booking variables
int quantity;
public adapterTickets(Context context, List<DataTick> dataList){
this.context = context;
this.dataList = dataList;
}
@NonNull
@Override
public MyViewHolderTic onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_tickets, parent, false);
return new MyViewHolderTic(view);
}
@Override
public void onBindViewHolder(@NonNull MyViewHolderTic holder, int position) {
holder.ticType.setText(dataList.get(position).getTicketsType());
holder.ticQuantity.setText(String.valueOf(dataList.get(position).getTicketsQuantity()));
holder.ticPrice.setText(String.valueOf(dataList.get(position).getTicketsPrice()));
holder.plusQuantity.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
quantity++;
holder.quantityNumber.setText(String.valueOf(quantity));
}
});
holder.minusQuantity.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if(quantity == 0)
Toast.makeText(context.getApplicationContext(), "Can't decrease quantity < 0", Toast.LENGTH_SHORT).show();
else {
quantity--;
holder.quantityNumber.setText(String.valueOf(quantity));
}
}
});
holder.bookTicket.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(context, BookingsActivity.class);
intent.putExtra("TypeTic", dataList.get(holder.getAdapterPosition()).getTicketsType());
intent.putExtra("NrOfTick", quantity);
context.startActivity(intent);
}
});
}
@Override
public int getItemCount() {
return dataList.size();
}
}
class MyViewHolderTic extends RecyclerView.ViewHolder{
TextView ticType, ticQuantity, ticPrice;
ImageButton plusQuantity, minusQuantity;
TextView quantityNumber;
Button bookTicket;
public MyViewHolderTic(@NonNull View itemView) {
super(itemView);
ticType = itemView.findViewById(R.id.ticType);
ticQuantity = itemView.findViewById(R.id.ticQuantity);
ticPrice = itemView.findViewById(R.id.ticPrice);
plusQuantity = itemView.findViewById(R.id.addQuantity);
minusQuantity = itemView.findViewById(R.id.subQuantity);
quantityNumber = itemView.findViewById(R.id.quantity);
bookTicket = itemView.findViewById(R.id.bookBtn);
}
}
package com.example.assignment;
import android.content.Context;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.cardview.widget.CardView;
import androidx.recyclerview.widget.RecyclerView;
import java.util.List;
public class myAdapter extends RecyclerView.Adapter<MyViewHolder> {
private Context context;
private List<DataClass> dataList;
public void setSearchList(List<DataClass> dataSearchList){
this.dataList = dataSearchList;
notifyDataSetChanged();
}
public myAdapter(Context context, List<DataClass> dataList){
this.context = context;
this.dataList = dataList;
}
@NonNull
@Override
public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_item, parent, false);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
holder.recImage.setImageResource(dataList.get(position).getDataImage());
holder.recTitle.setText(dataList.get(position).getDataTitle());
holder.recDesc.setText(dataList.get(position).getDataDesc());
holder.recDate.setText(dataList.get(position).getDataDate());
holder.recCard.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(context, DetailActivity.class);
intent.putExtra("Image", dataList.get(holder.getAdapterPosition()).getDataImage());
intent.putExtra("Title", dataList.get(holder.getAdapterPosition()).getDataTitle());
intent.putExtra("Desc", dataList.get(holder.getAdapterPosition()).getDataDesc());
context.startActivity(intent);
}
});
}
@Override
public int getItemCount() {
return dataList.size();
}
}
class MyViewHolder extends RecyclerView.ViewHolder{
// here are the views on which I inflate the data
ImageView recImage;
TextView recTitle, recDesc, recDate;
CardView recCard;
public MyViewHolder(@NonNull View itemView){
super(itemView);
recImage = itemView.findViewById(R.id.recImage);
recTitle = itemView.findViewById(R.id.recTitle);
recDesc = itemView.findViewById(R.id.recDesc);
recDate = itemView.findViewById(R.id.recDate);
recCard = itemView.findViewById(R.id.recCard);
}
}
package com.example.assignment;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.telephony.CellSignalStrength;
import com.google.android.material.transition.MaterialElevationScale;
public class myDBHelper extends SQLiteOpenHelper {
public static final String DBNAME = "login.db"; // the name of the database
public myDBHelper(Context context) {
super(context, "login.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL("CREATE TABLE Users(id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT, name TEXT, surname TEXT, password TEXT)"); // Users table
sqLiteDatabase.execSQL("CREATE TABLE Tickets(id INTEGER PRIMARY KEY AUTOINCREMENT, performance TEXT, typeOfTick TEXT, totalTick TEXT, availableNr TEXT, price TEXT)"); // Tickets table
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
sqLiteDatabase.execSQL("DROP TABLE IF EXISTS Users");
}
public Boolean insertUser(String username, String password, String name, String surname){
// function for inserting user in database
SQLiteDatabase db = this.getWritableDatabase(); // get right to write in database
ContentValues values = new ContentValues(); // for values
values.put("username", username);
values.put("name", name);
values.put("surname", surname);
values.put("password", password); // put each value in its place in the table
long result = db.insert("Users", null, values);
if (result == -1) // if it didn't work return warning message
return false;
else
return true;
}
public Boolean insertTicket(String performance, String ticType, int totalTic, int available, int price){
// function for inserting tickets in database
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("performance", performance);
values.put("typeOfTick", ticType);
values.put("totalTick", totalTic);
values.put("availableNr", available);
values.put("price", price);
long result = db.insert("Tickets", null, values);
if (result == -1)
return false;
else
return true;
}
public Boolean checkUserName(String username){
// checking if the user already exists in the database
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery("SELECT * FROM Users WHERE username=?", new String[] {username});
if (cursor.getCount() > 0)
return true;
else
return false;
}
public Boolean checkUsernamePassword(String username, String password){
// same function, but checking password too
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery("SELECT * FROM Users WHERE username=? AND password=?", new String[] {username, password});
if (cursor.getCount() > 0)
return true;
else
return false;
}
public String ticketsType(String performance){
// function that loops through the database to display tickets for a certain performance
String value = "";
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery("SELECT * FROM Tickets WHERE performance=?", new String[] {performance});
while (cursor.moveToNext()){
value = value + cursor.getString(2) + ",";
}
cursor.close();
return value;
}
public String setPrice(String title, String type){
SQLiteDatabase db = this.getWritableDatabase();
String value = "";
Cursor cursor = db.rawQuery("SELECT * FROM Tickets WHERE performance=? AND typeOfTick=?", new String[] {title, type});
value = cursor.getString(5);
return value;
}
}
<vector xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:aapt="http://schemas.android.com/aapt"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
<aapt:attr name="android:fillColor">
<gradient
android:endX="85.84757"
android:endY="92.4963"
android:startX="42.9492"
android:startY="49.59793"
android:type="linear">
<item
android:color="#44000000"
android:offset="0.0" />
<item
android:color="#00000000"
android:offset="1.0" />
</gradient>
</aapt:attr>
</path>
<path
android:fillColor="#FFFFFF"
android:fillType="nonZero"
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
android:strokeWidth="1"
android:strokeColor="#00000000" />
</vector>
\ No newline at end of file
<vector android:height="24dp" android:tint="#201E20"
android:viewportHeight="24" android:viewportWidth="24"
android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M19,6.41L17.59,5 12,10.59 6.41,5 5,6.41 10.59,12 5,17.59 6.41,19 12,13.41 17.59,19 19,17.59 13.41,12z"/>
</vector>
<vector android:height="24dp" android:tint="#201E20"
android:viewportHeight="24" android:viewportWidth="24"
android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M15.5,14h-0.79l-0.28,-0.27C15.41,12.59 16,11.11 16,9.5 16,5.91 13.09,3 9.5,3S3,5.91 3,9.5 5.91,16 9.5,16c1.61,0 3.09,-0.59 4.23,-1.57l0.27,0.28v0.79l5,4.99L20.49,19l-4.99,-5zM9.5,14C7.01,14 5,11.99 5,9.5S7.01,5 9.5,5 14,7.01 14,9.5 11.99,14 9.5,14z"/>
</vector>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners
android:bottomLeftRadius="16dp"
android:bottomRightRadius="16dp" />
<stroke
android:color="@color/beige"
android:width="2dp" />
</shape>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#DDC3A5" />
<stroke android:width="3dp" android:color="#201E20" />
</shape>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path
android:fillColor="#3DDC84"
android:pathData="M0,0h108v108h-108z" />
<path
android:fillColor="#00000000"
android:pathData="M9,0L9,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,0L19,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,0L29,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,0L39,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,0L49,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,0L59,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,0L69,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,0L79,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M89,0L89,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M99,0L99,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,9L108,9"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,19L108,19"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,29L108,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,39L108,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,49L108,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,59L108,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,69L108,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,79L108,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,89L108,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,99L108,99"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,29L89,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,39L89,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,49L89,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,59L89,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,69L89,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,79L89,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,19L29,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,19L39,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,19L49,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,19L59,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,19L69,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,19L79,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
</vector>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners
android:radius="20dp" />
<stroke
android:color="#201E20"
android:width="2dp" />
</shape>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:app="http://schemas.android.com/apk/res-auto"
app:fontProviderAuthority="com.google.android.gms.fonts"
app:fontProviderPackage="com.google.android.gms"
app:fontProviderQuery="Libre Caslon Display"
app:fontProviderCerts="@array/com_google_android_gms_fonts_certs">
</font-family>
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:app="http://schemas.android.com/apk/res-auto"
app:fontProviderAuthority="com.google.android.gms.fonts"
app:fontProviderPackage="com.google.android.gms"
app:fontProviderQuery="Libre Caslon Text"
app:fontProviderCerts="@array/com_google_android_gms_fonts_certs">
</font-family>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
tools:context=".BookingsActivity">
<TextView
android:id="@+id/bookTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="12dp"
android:layout_marginTop="16dp"
android:layout_marginEnd="12dp"
android:fontFamily="@font/libre_caslon_display1"
android:gravity="center"
android:text="Bookings"
android:textColor="#201E20"
android:textSize="24dp"
android:textStyle="bold" />
<androidx.recyclerview.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/recyclerViewTic"
android:layout_marginTop="8dp"
android:scrollbars="vertical"
app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
android:layout_below="@+id/bookTitle"/>
</RelativeLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@color/beige"
tools:context=".DetailActivity">
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/detailTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="14dp"
android:layout_marginBottom="12dp"
android:fontFamily="@font/libre_caslon_display1"
android:text="Title"
android:textColor="#201E20"
android:textSize="24dp"
android:textStyle="bold" />
<ImageView
android:layout_width="400dp"
android:layout_height="200dp"
android:id="@+id/detailImage"
android:padding="8dp"
android:layout_gravity="center"
android:src="@drawable/merchantofvenice"
android:scaleType="centerCrop" />
<Button
android:id="@+id/ticketsBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:backgroundTint="@color/tan"
android:textColor="#201E20"
android:fontFamily="@font/libre_caslon_display1"
android:text="buy tickets"
android:layout_gravity="center"
android:textSize="15sp" />
<TextView
android:id="@+id/detailDesc"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="10dp"
android:fontFamily="@font/libre_caslon_text2"
android:padding="20dp"
android:text="Description"
android:textColor="#201E20"
android:textSize="18sp" />
</LinearLayout>
</ScrollView>
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
tools:context=".HomeActivity">
<androidx.appcompat.widget.SearchView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:layout_marginEnd="12dp"
android:layout_marginStart="12dp"
android:id="@+id/search"
android:backgroundTint="@color/beige"
app:iconifiedByDefault="false"
app:searchHintIcon="@null"
app:queryHint="Search..."
android:focusable="false"
app:closeIcon="@drawable/baseline_clear_24"
app:searchIcon="@drawable/baseline_search_24"
android:background="@drawable/search_bkg" />
<androidx.recyclerview.widget.RecyclerView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/recyclerView"
android:layout_marginTop="8dp"
android:scrollbars="vertical"
android:layout_below="@id/search"/>
</RelativeLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="10dp"
android:orientation="vertical"
android:background="#E0A96D"
tools:context=".LoginActivity">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:layout_marginBottom="40dp"
android:fontFamily="@font/libre_caslon_display1"
android:gravity="center_horizontal"
android:text="Login"
android:textColor="#201E20"
android:textSize="50sp" />
<EditText
android:id="@+id/usernameLog"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="15dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Username"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:textSize="20sp" />
<EditText
android:id="@+id/passwordLog"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="30dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Password"
android:inputType="textPassword"
android:paddingLeft="20sp"
android:textColorHint="#201E20"
android:textSize="20sp" />
<Button
android:id="@+id/signInLog"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:backgroundTint="#201E20"
android:fontFamily="@font/libre_caslon_display1"
android:text="sign in"
android:textSize="25sp" />
<Button
android:id="@+id/signUpLog"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="10dp"
android:backgroundTint="#E0A96D"
android:fontFamily="@font/libre_caslon_text2"
android:text="don't have an account yet?"
android:textColor="#201E20"
android:textSize="18sp"
app:strokeColor="#201E20"
app:strokeWidth="1dp" />
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="10dp"
android:orientation="vertical"
android:background="#E0A96D"
tools:context=".MainActivity">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:layout_marginBottom="40dp"
android:fontFamily="@font/libre_caslon_display1"
android:gravity="center_horizontal"
android:text="Registration"
android:textColor="#201E20"
android:textSize="50sp" />
<EditText
android:id="@+id/firstname"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="15dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="First name"
android:inputType="textPersonName"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:digits="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
android:textSize="20sp" />
<EditText
android:id="@+id/surname"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="15dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Surname"
android:inputType="textPersonName"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:digits="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
android:textSize="20sp" />
<EditText
android:id="@+id/username"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="15dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Username"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:textSize="20sp" />
<EditText
android:id="@+id/password"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="15dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Password"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:textSize="20sp" />
<EditText
android:id="@+id/repass"
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_marginBottom="30dp"
android:background="@drawable/edittextbackground"
android:fontFamily="@font/libre_caslon_text2"
android:hint="Confirm Password"
android:paddingLeft="20dp"
android:textColorHint="#201E20"
android:textSize="20sp" />
<Button
android:id="@+id/signup"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:backgroundTint="#201E20"
android:fontFamily="@font/libre_caslon_display1"
android:text="sign up"
android:textSize="25sp" />
<Button
android:id="@+id/signin"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="10dp"
android:backgroundTint="#E0A96D"
android:fontFamily="@font/libre_caslon_text2"
android:text="already have an account?"
android:textColor="#201E20"
android:textSize="18sp"
app:strokeColor="#201E20"
app:strokeWidth="1dp" />
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
tools:context=".BookingsActivity">
<TextView
android:id="@+id/ticTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="12dp"
android:layout_marginTop="16dp"
android:layout_marginEnd="12dp"
android:fontFamily="@font/libre_caslon_display1"
android:gravity="center"
android:text="Title"
android:textColor="#201E20"
android:textSize="24dp"
android:textStyle="bold" />
<androidx.recyclerview.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/recyclerViewTic"
android:layout_marginTop="8dp"
android:scrollbars="vertical"
app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
android:layout_below="@+id/ticTitle"/>
</RelativeLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
xmlns:app="http://schemas.android.com/apk/res-auto">
<androidx.cardview.widget.CardView
android:layout_width="match_parent"
android:layout_height="210dp"
android:id="@+id/ticCard"
app:cardElevation="8dp"
app:cardCornerRadius="16dp"
android:backgroundTint="@color/beige"
app:cardUseCompatPadding="true">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="5.5">
<TextView
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="2"
android:scaleType="centerCrop"
android:text="Title"
android:textSize="20sp"
android:maxLines="1"
android:textColor="#201E20"
android:id="@+id/bookTitle"/>
<TextView
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="2"
android:scaleType="centerCrop"
android:text="Type"
android:textSize="20sp"
android:maxLines="1"
android:textColor="#201E20"
android:id="@+id/bookType"/>
<TextView
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="2"
android:scaleType="centerCrop"
android:text="Type"
android:textSize="20sp"
android:maxLines="1"
android:textColor="#201E20"
android:id="@+id/nrOfTick"/>
<Button
android:id="@+id/cancelBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:layout_marginLeft="50dp"
android:backgroundTint="@color/tan"
android:textColor="#201E20"
android:fontFamily="@font/libre_caslon_display1"
android:text="Cancel"
android:layout_gravity="center"
android:textSize="15sp" />
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
xmlns:app="http://schemas.android.com/apk/res-auto">
<androidx.cardview.widget.CardView
android:layout_width="wrap_content"
android:layout_height="250dp"
android:id="@+id/recCard"
android:backgroundTint="@color/beige"
app:cardElevation="8dp"
app:cardCornerRadius="16dp"
app:cardUseCompatPadding="true">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="5.5">
<ImageView
android:layout_width="wrap_content"
android:layout_height="0dp"
android:id="@+id/recImage"
android:layout_weight="4"
android:scaleType="centerCrop"
android:src="@drawable/merchantofvenice"
app:layout_constrainedHeight="true"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:weightSum="2"
android:layout_weight="1.5"
android:background="@drawable/card_border">
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1.3"
android:padding="10dp"
android:orientation="vertical">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Title"
android:textStyle="bold"
android:textSize="20sp"
android:maxLines="1"
android:textColor="#201E20"
android:id="@+id/recTitle"/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Desc"
android:textSize="18sp"
android:id="@+id/recDesc"
android:maxLines="0" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="0.7"
android:gravity="center">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Date"
android:textColor="#201E20"
android:textSize="18sp"
android:textAlignment="center"
android:id="@+id/recDate"/>
</LinearLayout>
</LinearLayout>
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
xmlns:app="http://schemas.android.com/apk/res-auto">
<androidx.cardview.widget.CardView
android:layout_width="match_parent"
android:layout_height="210dp"
android:id="@+id/ticCard"
app:cardElevation="8dp"
app:cardCornerRadius="16dp"
android:backgroundTint="@color/beige"
app:cardUseCompatPadding="true">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:weightSum="5.5">
<TextView
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="2"
android:scaleType="centerCrop"
android:text="Type"
android:textSize="20sp"
android:maxLines="1"
android:textColor="#201E20"
android:id="@+id/ticType"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<ImageButton
android:id="@+id/subQuantity"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_marginLeft="50dp"
android:background="@drawable/minus"
android:scaleType="centerCrop" />
<TextView
android:id="@+id/quantity"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="20dp"
android:layout_marginRight="20dp"
android:layout_toRightOf="@+id/addQuantity"
android:text="0"
android:textColor="#201E20"
android:textSize="28sp"
android:textStyle="bold" />
<ImageButton
android:id="@+id/addQuantity"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_marginBottom="10dp"
android:layout_toRightOf="@+id/quantity"
android:background="@drawable/plus" />
<Button
android:id="@+id/bookBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="5dp"
android:layout_marginLeft="50dp"
android:backgroundTint="@color/tan"
android:textColor="#201E20"
android:fontFamily="@font/libre_caslon_display1"
android:text="Book"
android:layout_gravity="center"
android:textSize="15sp" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:weightSum="2"
android:layout_weight="2.5"
android:background="@drawable/card_border">
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1.3"
android:padding="10dp"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Availability: " />
<TextView
android:id="@+id/ticQuantity"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:maxLines="1"
android:text="Availability"
android:textColor="#201E20"
android:textSize="20sp" />
</LinearLayout>
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="0.7"
android:orientation="vertical"
android:gravity="center">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Price:" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Price"
android:textColor="#201E20"
android:textSize="18sp"
android:textAlignment="center"
android:id="@+id/ticPrice"/>
</LinearLayout>
</LinearLayout>
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>
\ No newline at end of file
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.Assignment" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_200</item>
<item name="colorPrimaryVariant">@color/purple_700</item>
<item name="colorOnPrimary">@color/black</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_200</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="purple_200">#FFBB86FC</color>
<color name="purple_500">#FF6200EE</color>
<color name="purple_700">#FF3700B3</color>
<color name="teal_200">#FF03DAC5</color>
<color name="teal_700">#FF018786</color>
<color name="black">#FF000000</color>
<color name="white">#FFFFFFFF</color>
<color name="tan">#E0A96D</color>
<color name="beige">#DDC3A5</color>
</resources>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?>
<resources>
<array name="com_google_android_gms_fonts_certs">
<item>@array/com_google_android_gms_fonts_certs_dev</item>
<item>@array/com_google_android_gms_fonts_certs_prod</item>
</array>
<string-array name="com_google_android_gms_fonts_certs_dev">
<item>
MIIEqDCCA5CgAwIBAgIJANWFuGx90071MA0GCSqGSIb3DQEBBAUAMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbTAeFw0wODA0MTUyMzM2NTZaFw0zNTA5MDEyMzM2NTZaMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbTCCASAwDQYJKoZIhvcNAQEBBQADggENADCCAQgCggEBANbOLggKv+IxTdGNs8/TGFy0PTP6DHThvbbR24kT9ixcOd9W+EaBPWW+wPPKQmsHxajtWjmQwWfna8mZuSeJS48LIgAZlKkpFeVyxW0qMBujb8X8ETrWy550NaFtI6t9+u7hZeTfHwqNvacKhp1RbE6dBRGWynwMVX8XW8N1+UjFaq6GCJukT4qmpN2afb8sCjUigq0GuMwYXrFVee74bQgLHWGJwPmvmLHC69EH6kWr22ijx4OKXlSIx2xT1AsSHee70w5iDBiK4aph27yH3TxkXy9V89TDdexAcKk/cVHYNnDBapcavl7y0RiQ4biu8ymM8Ga/nmzhRKya6G0cGw8CAQOjgfwwgfkwHQYDVR0OBBYEFI0cxb6VTEM8YYY6FbBMvAPyT+CyMIHJBgNVHSMEgcEwgb6AFI0cxb6VTEM8YYY6FbBMvAPyT+CyoYGapIGXMIGUMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEQMA4GA1UEChMHQW5kcm9pZDEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDEiMCAGCSqGSIb3DQEJARYTYW5kcm9pZEBhbmRyb2lkLmNvbYIJANWFuGx90071MAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEEBQADggEBABnTDPEF+3iSP0wNfdIjIz1AlnrPzgAIHVvXxunW7SBrDhEglQZBbKJEk5kT0mtKoOD1JMrSu1xuTKEBahWRbqHsXclaXjoBADb0kkjVEJu/Lh5hgYZnOjvlba8Ld7HCKePCVePoTJBdI4fvugnL8TsgK05aIskyY0hKI9L8KfqfGTl1lzOv2KoWD0KWwtAWPoGChZxmQ+nBli+gwYMzM1vAkP+aayLe0a1EQimlOalO762r0GXO0ks+UeXde2Z4e+8S/pf7pITEI/tP+MxJTALw9QUWEv9lKTk+jkbqxbsh8nfBUapfKqYn0eidpwq2AzVp3juYl7//fKnaPhJD9gs=
</item>
</string-array>
<string-array name="com_google_android_gms_fonts_certs_prod">
<item>
MIIEQzCCAyugAwIBAgIJAMLgh0ZkSjCNMA0GCSqGSIb3DQEBBAUAMHQxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRYwFAYDVQQHEw1Nb3VudGFpbiBWaWV3MRQwEgYDVQQKEwtHb29nbGUgSW5jLjEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDAeFw0wODA4MjEyMzEzMzRaFw0zNjAxMDcyMzEzMzRaMHQxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMRYwFAYDVQQHEw1Nb3VudGFpbiBWaWV3MRQwEgYDVQQKEwtHb29nbGUgSW5jLjEQMA4GA1UECxMHQW5kcm9pZDEQMA4GA1UEAxMHQW5kcm9pZDCCASAwDQYJKoZIhvcNAQEBBQADggENADCCAQgCggEBAKtWLgDYO6IIrgqWbxJOKdoR8qtW0I9Y4sypEwPpt1TTcvZApxsdyxMJZ2JORland2qSGT2y5b+3JKkedxiLDmpHpDsz2WCbdxgxRczfey5YZnTJ4VZbH0xqWVW/8lGmPav5xVwnIiJS6HXk+BVKZF+JcWjAsb/GEuq/eFdpuzSqeYTcfi6idkyugwfYwXFU1+5fZKUaRKYCwkkFQVfcAs1fXA5V+++FGfvjJ/CxURaSxaBvGdGDhfXE28LWuT9ozCl5xw4Yq5OGazvV24mZVSoOO0yZ31j7kYvtwYK6NeADwbSxDdJEqO4k//0zOHKrUiGYXtqw/A0LFFtqoZKFjnkCAQOjgdkwgdYwHQYDVR0OBBYEFMd9jMIhF1Ylmn/Tgt9r45jk14alMIGmBgNVHSMEgZ4wgZuAFMd9jMIhF1Ylmn/Tgt9r45jk14aloXikdjB0MQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEWMBQGA1UEBxMNTW91bnRhaW4gVmlldzEUMBIGA1UEChMLR29vZ2xlIEluYy4xEDAOBgNVBAsTB0FuZHJvaWQxEDAOBgNVBAMTB0FuZHJvaWSCCQDC4IdGZEowjTAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBBAUAA4IBAQBt0lLO74UwLDYKqs6Tm8/yzKkEu116FmH4rkaymUIE0P9KaMftGlMexFlaYjzmB2OxZyl6euNXEsQH8gjwyxCUKRJNexBiGcCEyj6z+a1fuHHvkiaai+KL8W1EyNmgjmyy8AW7P+LLlkR+ho5zEHatRbM/YAnqGcFh5iZBqpknHf1SKMXFh4dd239FJ1jWYfbMDMy3NS5CTMQ2XFI1MvcyUTdZPErjQfTbQe3aDQsQcafEQPD+nqActifKZ0Np0IS9L9kR/wbNvyz6ENwPiTrjV2KRkEjH78ZMcUQXg0L3BYHJ3lc69Vs5Ddf9uUGGMYldX3WfMBEmh/9iFBDAaTCK
</item>
</string-array>
</resources>
<?xml version="1.0" encoding="utf-8"?>
<resources>
<array name="preloaded_fonts" translatable="false">
<item>@font/libre_caslon_display1</item>
<item>@font/libre_caslon_text2</item>
</array>
</resources>
<resources>
<string name="app_name">Theatre Plays</string>
<string name="merchant"><i>The Merchant of Venice by William Shakespeare</i>\n\n
Time and location: 20:00 Sunday April 23 2023, Merchant Adventurer\s Hall, York\n\n
<b>Important:</b>\n\n
<b>1. Has wheelchair access</b>\n\n
</string>
<string name="hamlet"><i>Hamlet by William Shakespeare</i>\n\n
Time and location: 18:00 19 May 2023, Clifford\s Tower, York\n\n
<b>Important:</b>\n\n
<b>1. Must be able to climb 20 steps</b>\n\n
<b>2. Performance includes flashing lights</b>\n\n
<b>3. Users are required to tick a box to consent to being splattered with fake blood during the performance</b>
</string>
<string name="midsummer"><i>A Midsummer Night\s Dream by William Shakespeare</i>\n\n
Time and location: 19:00 Saturday 3 June 2023, Dean\s Park, York\n\n
<b>Important:</b>\n\n
<b>1. Has wheelchair access</b>\n\n
<b>2. Performance includes flashing lights</b>\n\n
</string>
<string name="oedipus"><i>Oedipus the King by Sophocles</i>\n\n
Time and location: 20:00 Fri 28 July, St Mary\s Abbey, Museum Gardens, York\n\n
<b>Important:</b>\n\n
<b>1. Has wheelchair access</b>
</string>
<string name="tempest"><i>The Tempest by William Shakespeare</i>\n\n
Time and location: 14:00 Saturday 19 August, Milleneum Bridge, York\n\n
<b>Important:</b>\n\n
<b>1. Has wheelchair access</b>\n\n
<b>2. Performance includes flashing lights</b>
</string>
<string name="antigone"><i>Antigone by Sophocles</i>
Time and location: 21:00 Thursday 20 September, Crypt, York Minster, York\n\n
<b>1. Must be able to climb 20 steps</b>
</string>
</resources>
\ No newline at end of file
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.Assignment" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/tan</item>
<item name="colorPrimaryVariant">@color/tan</item>
<item name="colorOnPrimary">@color/white</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_700</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?><!--
Sample backup rules file; uncomment and customize as necessary.
See https://developer.android.com/guide/topics/data/autobackup
for details.
Note: This file is ignored for devices older that API 31
See https://developer.android.com/about/versions/12/backup-restore
-->
<full-backup-content>
<!--
<include domain="sharedpref" path="."/>
<exclude domain="sharedpref" path="device.xml"/>
-->
</full-backup-content>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8"?><!--
Sample data extraction rules file; uncomment and customize as necessary.
See https://developer.android.com/about/versions/12/backup-restore#xml-changes
for details.
-->
<data-extraction-rules>
<cloud-backup>
<!-- TODO: Use <include> and <exclude> to control what is backed up.
<include .../>
<exclude .../>
-->
</cloud-backup>
<!--
<device-transfer>
<include .../>
<exclude .../>
</device-transfer>
-->
</data-extraction-rules>
\ No newline at end of file
package com.example.assignment;
import org.junit.Test;
import static org.junit.Assert.*;
/**
* Example local unit test, which will execute on the development machine (host).
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
public class ExampleUnitTest {
@Test
public void addition_isCorrect() {
assertEquals(4, 2 + 2);
}
}
\ No newline at end of file
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '7.4.1' apply false
id 'com.android.library' version '7.4.1' apply false
}
\ No newline at end of file
# Project-wide Gradle settings.
# IDE (e.g. Android Studio) users:
# Gradle settings configured through the IDE *will override*
# any settings specified in this file.
# For more details on how to configure your build environment visit
# http://www.gradle.org/docs/current/userguide/build_environment.html
# Specifies the JVM arguments used for the daemon process.
# The setting is particularly useful for tweaking memory settings.
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
# When configured, Gradle will run in incubating parallel mode.
# This option should only be used with decoupled projects. More details, visit
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
# org.gradle.parallel=true
# AndroidX package structure to make it clearer which packages are bundled with the
# Android operating system, and which are packaged with your app's APK
# https://developer.android.com/topic/libraries/support-library/androidx-rn
android.useAndroidX=true
# Enables namespacing of each library's R class so that its R class includes only the
# resources declared in the library itself and none from the library's dependencies,
# thereby reducing the size of the R class for that library
android.nonTransitiveRClass=true
\ No newline at end of file
#Mon May 15 20:15:38 BST 2023
distributionBase=GRADLE_USER_HOME
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
#!/usr/bin/env sh
#
# Copyright 2015 the original author or authors.
#
# 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
#
# https://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.
#
##############################################################################
##
## Gradle start up script for UN*X
##
##############################################################################
# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null
APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"
warn () {
echo "$*"
}
die () {
echo
echo "$*"
echo
exit 1
}
# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
nonstop=false
case "`uname`" in
CYGWIN* )
cygwin=true
;;
Darwin* )
darwin=true
;;
MINGW* )
msys=true
;;
NONSTOP* )
nonstop=true
;;
esac
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD="java"
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
MAX_FD_LIMIT=`ulimit -H -n`
if [ $? -eq 0 ] ; then
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
MAX_FD="$MAX_FD_LIMIT"
fi
ulimit -n $MAX_FD
if [ $? -ne 0 ] ; then
warn "Could not set maximum file descriptor limit: $MAX_FD"
fi
else
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
fi
fi
# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi
# For Cygwin or MSYS, switch paths to Windows format before running java
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
JAVACMD=`cygpath --unix "$JAVACMD"`
# We build the pattern for arguments to be converted via cygpath
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
SEP=""
for dir in $ROOTDIRSRAW ; do
ROOTDIRS="$ROOTDIRS$SEP$dir"
SEP="|"
done
OURCYGPATTERN="(^($ROOTDIRS))"
# Add a user-defined pattern to the cygpath arguments
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
fi
# Now convert the arguments - kludge to limit ourselves to /bin/sh
i=0
for arg in "$@" ; do
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
else
eval `echo args$i`="\"$arg\""
fi
i=`expr $i + 1`
done
case $i in
0) set -- ;;
1) set -- "$args0" ;;
2) set -- "$args0" "$args1" ;;
3) set -- "$args0" "$args1" "$args2" ;;
4) set -- "$args0" "$args1" "$args2" "$args3" ;;
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
esac
fi
# Escape application args
save () {
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
echo " "
}
APP_ARGS=`save "$@"`
# Collect all arguments for the java command, following the shell quoting and substitution rules
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
exec "$JAVACMD" "$@"
@rem
@rem Copyright 2015 the original author or authors.
@rem
@rem Licensed under the Apache License, Version 2.0 (the "License");
@rem you may not use this file except in compliance with the License.
@rem You may obtain a copy of the License at
@rem
@rem https://www.apache.org/licenses/LICENSE-2.0
@rem
@rem Unless required by applicable law or agreed to in writing, software
@rem distributed under the License is distributed on an "AS IS" BASIS,
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@rem See the License for the specific language governing permissions and
@rem limitations under the License.
@rem
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################
@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto execute
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute
echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:execute
@rem Setup the command line
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1
:mainEnd
if "%OS%"=="Windows_NT" endlocal
:omega
pluginManagement {
repositories {
google()
mavenCentral()
gradlePluginPortal()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
google()
mavenCentral()
}
}
rootProject.name = "Assignment"
include ':app'
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment