Compare commits

...

2 Commits

Author SHA1 Message Date
Pranathi Bhogaraju 55420679b1 add 4 years ago
Pranathi Bhogaraju 71187f1ada add 4 years ago
143 changed files with 19468 additions and 0 deletions
Split View
  1. 33
      BackEnd/DailyCart_DD/.gitignore
  2. 117
      BackEnd/DailyCart_DD/.mvn/wrapper/MavenWrapperDownloader.java
  3. BIN
      BackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.jar
  4. 2
      BackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.properties
  5. 310
      BackEnd/DailyCart_DD/mvnw
  6. 182
      BackEnd/DailyCart_DD/mvnw.cmd
  7. 95
      BackEnd/DailyCart_DD/pom.xml
  8. 14
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/CorsConfig.java
  9. 13
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/DailyCartDdApplication.java
  10. 57
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/SecurityConfig.java
  11. 44
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/config/MessagingConfig.java
  12. 127
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CartController.java
  13. 46
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CategoryController.java
  14. 117
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/OrderController.java
  15. 70
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/ProductController.java
  16. 65
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/UserController.java
  17. 86
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Cartdto.java
  18. 87
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Orderdto.java
  19. 77
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Cart.java
  20. 37
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Category.java
  21. 183
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Order.java
  22. 59
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/OrderStatus.java
  23. 81
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Product.java
  24. 117
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/User.java
  25. 32
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/publisher/OrderPublisher.java
  26. 26
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CartRepository.java
  27. 9
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CategoryRepository.java
  28. 19
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/OrderRepository.java
  29. 15
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/ProductRepository.java
  30. 20
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/UserRepository.java
  31. 23
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/CartService.java
  32. 27
      BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/MyUserDetailsService.java
  33. 16
      BackEnd/DailyCart_DD/src/main/resources/application.properties
  34. 19
      BackEnd/DailyCart_DD/src/test/java/com/myrestapp/demo/DailyCartDdApplicationTests.java
  35. 17
      FrontEnd/.browserslistrc
  36. 16
      FrontEnd/.editorconfig
  37. 45
      FrontEnd/.gitignore
  38. 27
      FrontEnd/README.md
  39. 109
      FrontEnd/angular.json
  40. 44
      FrontEnd/karma.conf.js
  41. 12104
      FrontEnd/package-lock.json
  42. 40
      FrontEnd/package.json
  43. 6
      FrontEnd/proxy.config.json
  44. BIN
      FrontEnd/src/1.jpg
  45. 754
      FrontEnd/src/10.htm
  46. BIN
      FrontEnd/src/11.png
  47. BIN
      FrontEnd/src/2.jpg
  48. BIN
      FrontEnd/src/3.jpg
  49. BIN
      FrontEnd/src/4.png
  50. BIN
      FrontEnd/src/5.png
  51. BIN
      FrontEnd/src/6.png
  52. BIN
      FrontEnd/src/7.jpg
  53. BIN
      FrontEnd/src/8.png
  54. BIN
      FrontEnd/src/9.png
  55. 38
      FrontEnd/src/app/app-routing.module.ts
  56. 0
      FrontEnd/src/app/app.component.css
  57. 32
      FrontEnd/src/app/app.component.html
  58. 35
      FrontEnd/src/app/app.component.spec.ts
  59. 30
      FrontEnd/src/app/app.component.ts
  60. 52
      FrontEnd/src/app/app.module.ts
  61. 0
      FrontEnd/src/app/auth/login/login.component.css
  62. 108
      FrontEnd/src/app/auth/login/login.component.html
  63. 25
      FrontEnd/src/app/auth/login/login.component.spec.ts
  64. 53
      FrontEnd/src/app/auth/login/login.component.ts
  65. 16
      FrontEnd/src/app/auth/service/auth-guard.service.spec.ts
  66. 21
      FrontEnd/src/app/auth/service/auth-guard.service.ts
  67. 16
      FrontEnd/src/app/auth/service/auth.service.spec.ts
  68. 22
      FrontEnd/src/app/auth/service/auth.service.ts
  69. 41
      FrontEnd/src/app/auth/service/user.service.ts
  70. 0
      FrontEnd/src/app/auth/signup/signup.component.css
  71. 125
      FrontEnd/src/app/auth/signup/signup.component.html
  72. 25
      FrontEnd/src/app/auth/signup/signup.component.spec.ts
  73. 45
      FrontEnd/src/app/auth/signup/signup.component.ts
  74. 0
      FrontEnd/src/app/components/banner/banner.component.css
  75. 19
      FrontEnd/src/app/components/banner/banner.component.html
  76. 25
      FrontEnd/src/app/components/banner/banner.component.spec.ts
  77. 29
      FrontEnd/src/app/components/banner/banner.component.ts
  78. 16
      FrontEnd/src/app/components/cart/cart.component.css
  79. 278
      FrontEnd/src/app/components/cart/cart.component.html
  80. 25
      FrontEnd/src/app/components/cart/cart.component.spec.ts
  81. 139
      FrontEnd/src/app/components/cart/cart.component.ts
  82. 0
      FrontEnd/src/app/components/category/category.component.css
  83. 1
      FrontEnd/src/app/components/category/category.component.html
  84. 25
      FrontEnd/src/app/components/category/category.component.spec.ts
  85. 15
      FrontEnd/src/app/components/category/category.component.ts
  86. 0
      FrontEnd/src/app/components/dairy/dairy.component.css
  87. 170
      FrontEnd/src/app/components/dairy/dairy.component.html
  88. 25
      FrontEnd/src/app/components/dairy/dairy.component.spec.ts
  89. 27
      FrontEnd/src/app/components/dairy/dairy.component.ts
  90. 0
      FrontEnd/src/app/components/fruits/fruits.component.css
  91. 171
      FrontEnd/src/app/components/fruits/fruits.component.html
  92. 25
      FrontEnd/src/app/components/fruits/fruits.component.spec.ts
  93. 27
      FrontEnd/src/app/components/fruits/fruits.component.ts
  94. 0
      FrontEnd/src/app/components/household/household.component.css
  95. 170
      FrontEnd/src/app/components/household/household.component.html
  96. 25
      FrontEnd/src/app/components/household/household.component.spec.ts
  97. 26
      FrontEnd/src/app/components/household/household.component.ts
  98. 0
      FrontEnd/src/app/components/order/order.component.css
  99. 273
      FrontEnd/src/app/components/order/order.component.html
  100. 25
      FrontEnd/src/app/components/order/order.component.spec.ts

33
BackEnd/DailyCart_DD/.gitignore

@ -0,0 +1,33 @@
HELP.md
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/

117
BackEnd/DailyCart_DD/.mvn/wrapper/MavenWrapperDownloader.java

@ -0,0 +1,117 @@
/*
* Copyright 2007-present 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.
*/
import java.net.*;
import java.io.*;
import java.nio.channels.*;
import java.util.Properties;
public class MavenWrapperDownloader {
private static final String WRAPPER_VERSION = "0.5.6";
/**
* Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided.
*/
private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/"
+ WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar";
/**
* Path to the maven-wrapper.properties file, which might contain a downloadUrl property to
* use instead of the default one.
*/
private static final String MAVEN_WRAPPER_PROPERTIES_PATH =
".mvn/wrapper/maven-wrapper.properties";
/**
* Path where the maven-wrapper.jar will be saved to.
*/
private static final String MAVEN_WRAPPER_JAR_PATH =
".mvn/wrapper/maven-wrapper.jar";
/**
* Name of the property which should be used to override the default download url for the wrapper.
*/
private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl";
public static void main(String args[]) {
System.out.println("- Downloader started");
File baseDirectory = new File(args[0]);
System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath());
// If the maven-wrapper.properties exists, read it and check if it contains a custom
// wrapperUrl parameter.
File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH);
String url = DEFAULT_DOWNLOAD_URL;
if(mavenWrapperPropertyFile.exists()) {
FileInputStream mavenWrapperPropertyFileInputStream = null;
try {
mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile);
Properties mavenWrapperProperties = new Properties();
mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream);
url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url);
} catch (IOException e) {
System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'");
} finally {
try {
if(mavenWrapperPropertyFileInputStream != null) {
mavenWrapperPropertyFileInputStream.close();
}
} catch (IOException e) {
// Ignore ...
}
}
}
System.out.println("- Downloading from: " + url);
File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH);
if(!outputFile.getParentFile().exists()) {
if(!outputFile.getParentFile().mkdirs()) {
System.out.println(
"- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'");
}
}
System.out.println("- Downloading to: " + outputFile.getAbsolutePath());
try {
downloadFileFromURL(url, outputFile);
System.out.println("Done");
System.exit(0);
} catch (Throwable e) {
System.out.println("- Error downloading");
e.printStackTrace();
System.exit(1);
}
}
private static void downloadFileFromURL(String urlString, File destination) throws Exception {
if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) {
String username = System.getenv("MVNW_USERNAME");
char[] password = System.getenv("MVNW_PASSWORD").toCharArray();
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
}
URL website = new URL(urlString);
ReadableByteChannel rbc;
rbc = Channels.newChannel(website.openStream());
FileOutputStream fos = new FileOutputStream(destination);
fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
fos.close();
rbc.close();
}
}

BIN
BackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.jar

2
BackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.properties

@ -0,0 +1,2 @@
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.2/apache-maven-3.8.2-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar

310
BackEnd/DailyCart_DD/mvnw

@ -0,0 +1,310 @@
#!/bin/sh
# ----------------------------------------------------------------------------
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if [ -z "$MAVEN_SKIP_RC" ] ; then
if [ -f /etc/mavenrc ] ; then
. /etc/mavenrc
fi
if [ -f "$HOME/.mavenrc" ] ; then
. "$HOME/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin=false;
darwin=false;
mingw=false
case "`uname`" in
CYGWIN*) cygwin=true ;;
MINGW*) mingw=true;;
Darwin*) darwin=true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if [ -z "$JAVA_HOME" ]; then
if [ -x "/usr/libexec/java_home" ]; then
export JAVA_HOME="`/usr/libexec/java_home`"
else
export JAVA_HOME="/Library/Java/Home"
fi
fi
;;
esac
if [ -z "$JAVA_HOME" ] ; then
if [ -r /etc/gentoo-release ] ; then
JAVA_HOME=`java-config --jre-home`
fi
fi
if [ -z "$M2_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
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
saveddir=`pwd`
M2_HOME=`dirname "$PRG"`/..
# make it fully qualified
M2_HOME=`cd "$M2_HOME" && pwd`
cd "$saveddir"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if $cygwin ; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --unix "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if $mingw ; then
[ -n "$M2_HOME" ] &&
M2_HOME="`(cd "$M2_HOME"; pwd)`"
[ -n "$JAVA_HOME" ] &&
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
fi
if [ -z "$JAVA_HOME" ]; then
javaExecutable="`which javac`"
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
# readlink(1) is not available as standard on Solaris 10.
readLink=`which readlink`
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
if $darwin ; then
javaHome="`dirname \"$javaExecutable\"`"
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
else
javaExecutable="`readlink -f \"$javaExecutable\"`"
fi
javaHome="`dirname \"$javaExecutable\"`"
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
JAVA_HOME="$javaHome"
export JAVA_HOME
fi
fi
fi
if [ -z "$JAVACMD" ] ; then
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
else
JAVACMD="`which java`"
fi
fi
if [ ! -x "$JAVACMD" ] ; then
echo "Error: JAVA_HOME is not defined correctly." >&2
echo " We cannot execute $JAVACMD" >&2
exit 1
fi
if [ -z "$JAVA_HOME" ] ; then
echo "Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir() {
if [ -z "$1" ]
then
echo "Path not specified to find_maven_basedir"
return 1
fi
basedir="$1"
wdir="$1"
while [ "$wdir" != '/' ] ; do
if [ -d "$wdir"/.mvn ] ; then
basedir=$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if [ -d "${wdir}" ]; then
wdir=`cd "$wdir/.."; pwd`
fi
# end of workaround
done
echo "${basedir}"
}
# concatenates all lines of a file
concat_lines() {
if [ -f "$1" ]; then
echo "$(tr -s '\n' ' ' < "$1")"
fi
}
BASE_DIR=`find_maven_basedir "$(pwd)"`
if [ -z "$BASE_DIR" ]; then
exit 1;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if [ -n "$MVNW_REPOURL" ]; then
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
else
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
fi
while IFS="=" read key value; do
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
esac
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
if [ "$MVNW_VERBOSE" = true ]; then
echo "Downloading from: $jarUrl"
fi
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
if $cygwin; then
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
fi
if command -v wget > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found wget ... using wget"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
wget "$jarUrl" -O "$wrapperJarPath"
else
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
fi
elif command -v curl > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found curl ... using curl"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
curl -o "$wrapperJarPath" "$jarUrl" -f
else
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Falling back to using Java to download"
fi
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if $cygwin; then
javaClass=`cygpath --path --windows "$javaClass"`
fi
if [ -e "$javaClass" ]; then
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
("$JAVA_HOME/bin/javac" "$javaClass")
fi
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
# Running the downloader
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Running MavenWrapperDownloader.java ..."
fi
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
if [ "$MVNW_VERBOSE" = true ]; then
echo $MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
# For Cygwin, switch paths to Windows format before running java
if $cygwin; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --path --windows "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
exec "$JAVACMD" \
$MAVEN_OPTS \
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

182
BackEnd/DailyCart_DD/mvnw.cmd

@ -0,0 +1,182 @@
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. 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,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%" == "on" pause
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
exit /B %ERROR_CODE%

95
BackEnd/DailyCart_DD/pom.xml

@ -0,0 +1,95 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.4</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>DailyCart_DD</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>DailyCart_DD</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.amqp</groupId>
<artifactId>spring-rabbit-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

14
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/CorsConfig.java

@ -0,0 +1,14 @@
package com.myrestapp.demo;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class CorsConfig implements WebMvcConfigurer{
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**");
}
}

13
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/DailyCartDdApplication.java

@ -0,0 +1,13 @@
package com.myrestapp.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DailyCartDdApplication {
public static void main(String[] args) {
SpringApplication.run(DailyCartDdApplication.class, args);
}
}

57
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/SecurityConfig.java

@ -0,0 +1,57 @@
package com.myrestapp.demo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.security.authentication.dao.DaoAuthenticationProvider;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import com.myrestapp.demo.service.MyUserDetailsService;
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter{
@Autowired
MyUserDetailsService myUserDetailsService;
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.antMatchers("/banner").permitAll()
.antMatchers("/products").permitAll()
.antMatchers("/profile").permitAll()
.antMatchers("/login").permitAll()
.antMatchers("/signup").permitAll()
.and()
.httpBasic();
http.cors();
http.csrf().disable();
}
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
auth.authenticationProvider(getAuthentication());
}
private DaoAuthenticationProvider getAuthentication() {
DaoAuthenticationProvider dao = new DaoAuthenticationProvider();
dao.setUserDetailsService(myUserDetailsService);
dao.setPasswordEncoder(getPasswordEncoder());
return dao;
}
@Bean
@Primary
protected PasswordEncoder getPasswordEncoder() {
return new BCryptPasswordEncoder();
}
}

44
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/config/MessagingConfig.java

@ -0,0 +1,44 @@
package com.myrestapp.demo.config;
import org.springframework.amqp.core.*;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.amqp.support.converter.MessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MessagingConfig {
/*public static final String QUEUE = "seattle_queue";
public static final String EXCHANGE = "seattle_exchange";
public static final String ROUTING_KEY = "seattle_routingKey";
@Bean
public Queue queue() {
return new Queue(QUEUE);
}
@Bean
public TopicExchange exchange() {
return new TopicExchange(EXCHANGE);
}
@Bean
public Binding binding(Queue queue, TopicExchange exchange) {
return BindingBuilder.bind(queue).to(exchange).with(ROUTING_KEY);
}
@Bean
public MessageConverter converter() {
return new Jackson2JsonMessageConverter();
}
@Bean
public AmqpTemplate template(ConnectionFactory connectionFactory) {
final RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
rabbitTemplate.setMessageConverter(converter());
return rabbitTemplate;
}*/
}

127
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CartController.java

@ -0,0 +1,127 @@
package com.myrestapp.demo.controller;
import java.util.ArrayList;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.dto.Cartdto;
import com.myrestapp.demo.model.Cart;
import com.myrestapp.demo.model.Product;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.CartRepository;
import com.myrestapp.demo.repository.ProductRepository;
import com.myrestapp.demo.repository.UserRepository;
import com.myrestapp.demo.service.CartService;
@RestController
public class CartController {
@Autowired
private CartRepository cartRepository;
@Autowired
private UserRepository userRepository;
@Autowired
private ProductRepository productRepository;
@Autowired
private CartService cartService;
@PostMapping("/cart/{uid}/{pid}")
public Cart postCart(@RequestBody Cart cart, @PathVariable("uid") Long uid, @PathVariable("pid") Long pid) {
cart.setUsers(userRepository.getById(uid));
Product productObj = productRepository.getById(pid);
cart.setProduct(productObj);
double q=1;
cart.setQuantity(q);
cart.setTotalPrice(cart.getProduct().getPrice() * cart.getQuantity());
return cartRepository.save(cart);
}
@GetMapping("/cart/{uid}")
public List<Cart> getCartByUser(@PathVariable("uid") Long uid) {
return cartRepository.getCartByUserId(uid);
}
@GetMapping("/cart")
public List<Cart> getCartOfAllUsers() {
return cartRepository.findAll();
}
@DeleteMapping("/cart/{cid}")
public void deleteFromCart(@PathVariable("cid") Long cid) {
cartRepository.deleteById(cid);
}
@DeleteMapping("/usercart/{uid}")
public void deleteUsetCart(@PathVariable("uid") Long uid) {
cartRepository.deleteAll(uid);
}
@GetMapping("/cartdto/{uid}")
public List<Cartdto> getCartdto(@PathVariable("uid") Long uid) {
List<Cart> list = new ArrayList<>();
List<Cartdto> listDto = new ArrayList<>();
list = cartRepository.getCartByUserId(uid);
for(Cart c : list) {
Cartdto cartDto = new Cartdto();
cartDto.setCid(c.getId());
cartDto.setQuantity(c.getQuantity());
cartDto.setTotalPrice(c.getQuantity()*c.getProduct().getPrice());
cartDto.setPid(c.getProduct().getId());
cartDto.setImage(c.getProduct().getImage());
cartDto.setPname(c.getProduct().getName());
cartDto.setPrice(c.getProduct().getPrice());
cartDto.setUid(c.getUsers().getId());
cartDto.setUname(c.getUsers().getName());
cartDto.setRole(c.getUsers().getRole());
cartDto.setApartment(c.getUsers().getApartment());
listDto.add(cartDto);
}
return listDto;
}
@PostMapping("/cartput/{cid}/{quantity}")//Post
public Double addquantity(@PathVariable("cid") Long cid, @PathVariable("quantity") Double quantity)
{
Cart cart=cartRepository.getById(cid);
cart.setQuantity(quantity);
cart.setTotalPrice(quantity*cart.getProduct().getPrice());
cartRepository.save(cart);
return cart.getTotalPrice();
}
@PostMapping("/cartsum/{uid}")
public Double getCartSum(@PathVariable("uid") Long uid) {
List<Cart> list = new ArrayList<>();
list = cartRepository.getCartByUserId(uid);
Cart cart=new Cart();
Double sum = 0.0;
for(Cart c : list)
{
sum=sum+ c.getTotalPrice();
}
for(Cart cc : list)
{
cc.setSubtotal(sum);
}
return sum;
}
}

46
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CategoryController.java

@ -0,0 +1,46 @@
package com.myrestapp.demo.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.model.Category;
import com.myrestapp.demo.repository.CategoryRepository;
@RestController
public class CategoryController {
@Autowired
private CategoryRepository categoryRepository;
@GetMapping("/category")
public List<Category> getAllCategories() {
return categoryRepository.findAll();
}
@PostMapping("/category")
public Category postCategory(@RequestBody Category category) {
return categoryRepository.save(category);
}
@PutMapping("/category/{id}")
public Category updateCategory(@RequestBody Category category, @PathVariable("id") Long categoryId) {
Category categoryObj = categoryRepository.getById(categoryId);
categoryObj.setName(category.getName());
return categoryRepository.save(categoryObj);
}
@DeleteMapping("/category/{id}")
public void deleteCategory(@PathVariable ("id") Long categoryId) {
categoryRepository.deleteById(categoryId);
}
}

117
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/OrderController.java

@ -0,0 +1,117 @@
package com.myrestapp.demo.controller;
import java.util.ArrayList;
import java.util.List;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.config.MessagingConfig;
import com.myrestapp.demo.model.OrderStatus;
import com.myrestapp.demo.dto.Orderdto;
import com.myrestapp.demo.model.Cart;
import com.myrestapp.demo.model.Order;
import com.myrestapp.demo.model.Product;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.CartRepository;
import com.myrestapp.demo.repository.OrderRepository;
import com.myrestapp.demo.repository.ProductRepository;
import com.myrestapp.demo.repository.UserRepository;
@RestController
public class OrderController {
@Autowired
private OrderRepository orderRepository;
@Autowired
private UserRepository userRepository;
@Autowired
private ProductRepository productRepository;
@Autowired
private CartRepository cartRepository;
@Autowired
private RabbitTemplate template;
@PostMapping("/order/{uid}")
public Long postOrder(@RequestBody Order order,@PathVariable("uid") Long uid)
{
long testvar = 0l;
List<Cart> list = cartRepository.getCartByUserId(uid);
for(Cart c : list)
{
Order ot=new Order();
ot.setOrderNumber(order.getOrderNumber());
testvar=ot.getOrderNumber();
ot.setSubtotal(c.getSubtotal());
ot.setCid(c.getId());
ot.setQuantity(c.getQuantity());
ot.setTotalPrice(c.getTotalPrice());
ot.setPid(c.getProduct().getId());
ot.setImage(c.getProduct().getImage());
ot.setPname(c.getProduct().getName());
ot.setPrice(c.getProduct().getPrice());
ot.setUid(c.getUsers().getId());
ot.setUname(c.getUsers().getName());
ot.setRole(c.getUsers().getRole());
ot.setApartment(c.getUsers().getApartment());
orderRepository.save(ot);
//OrderStatus orderStatus = new OrderStatus(ot, "PROCESS", "order placed succesfully in " + uid);
//template.convertAndSend(MessagingConfig.EXCHANGE, MessagingConfig.ROUTING_KEY, orderStatus);
cartRepository.deleteAll(uid);
}
return testvar;
}
@GetMapping("/orderdto/{uid}")
public List<Order> getAllOrdertest(@PathVariable("uid") Long uid){
return orderRepository.findByCustomerId(uid);
}
@PostMapping("/ordersum/{uid}/{onid}")
public Double getOrderSum(@PathVariable("uid") Long uid, @PathVariable("onid") Long onid) {
List<Order> list = orderRepository.findByCustomerId(uid);
Double sum = 0.0;
for(Order o:list)
{
if(o.getOrderNumber()==onid)
{
sum=sum + o.getTotalPrice();
}
}
return sum;
}
@GetMapping("/orderuid/{uid}")
public Double getOrderSumByUid(@PathVariable("uid") Long uid) {
List<Order> list = orderRepository.findByCustomerId(uid);
Double sum = 0.0;
for(Order o:list)
{
sum=sum + o.getTotalPrice();
}
return sum;
}
}

70
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/ProductController.java

@ -0,0 +1,70 @@
package com.myrestapp.demo.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.model.Category;
import com.myrestapp.demo.model.Product;
import com.myrestapp.demo.repository.CategoryRepository;
import com.myrestapp.demo.repository.ProductRepository;
@CrossOrigin(origins="http://localhost:8001",
methods= {RequestMethod.DELETE,RequestMethod.GET,RequestMethod.POST,RequestMethod.PUT})
@RestController
public class ProductController {
@Autowired
private ProductRepository productRepository;
@Autowired
private CategoryRepository categoryRepository;
@PostMapping("/product/{id}")
public Product postCategory(@RequestBody Product product, @PathVariable ("id") Long categoryId) {
Category categoryObj = categoryRepository.getById(categoryId);
product.setCategory(categoryObj);
return productRepository.save(product);
}
@GetMapping("/product")
public List<Product> getAllProducts() {
return productRepository.findAll();
}
@GetMapping("/product/{id}")
public Product getOneProduct(@PathVariable ("id") Long productId) {
return productRepository.getById(productId);
}
@DeleteMapping("/product/{id}")
public void deleteProduct(@PathVariable ("id") Long productId) {
productRepository.deleteById(productId);
}
@PutMapping("/product/{id}")
public Product updateProduct(@RequestBody Product product, @PathVariable("id") Long productId) {
Product productObj = productRepository.getById(productId);
productObj.setName(product.getName());
productObj.setPrice(product.getPrice());
productObj.setRating(product.getRating());
productObj.setImage(product.getImage());
return productRepository.save(productObj);
}
@GetMapping("/product/category/{category}")
public List<Product> getProductsByCategory(@PathVariable ("category") String categoryName) {
return productRepository.getProductsByCategory(categoryName);
}
}

65
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/UserController.java

@ -0,0 +1,65 @@
package com.myrestapp.demo.controller;
import java.security.Principal;
import java.util.Base64;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.UserRepository;
@RestController
public class UserController {
@Autowired
private UserRepository userRepository;
@Autowired
private PasswordEncoder passwordEncoder;
@PostMapping("/signup")
public void postUser(@RequestBody User user) {
String code = user.getUsername();
String username = new String(Base64.getDecoder().decode(code)).split(":")[0];
String password = new String(Base64.getDecoder().decode(code)).split(":")[1];
user.setUsername(username);
user.setPassword(password);
String encPassword = passwordEncoder.encode(user.getPassword());
user.setPassword(encPassword);
userRepository.save(user);
}
@GetMapping("/login")
public Principal login(Principal principal) {
if(principal.getName()==null)
throw new Error("Invalid Credentials");
return principal;
}
@GetMapping("/user/{uid}")
public User getUserById(@PathVariable("uid") Long uid)
{
return userRepository.getById(uid);
}
@GetMapping("/userid/{username}")
public Long getByUserName(@PathVariable("username") String username)
{
return userRepository.getIdByUsername(username);
}
@GetMapping("/username/{username}")
private User getDetails(@PathVariable("username") String username) {
return userRepository.getByUserName(username);
}
}

86
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Cartdto.java

@ -0,0 +1,86 @@
package com.myrestapp.demo.dto;
public class Cartdto
{
private Long cid;
private Double quantity;
private Double totalPrice;
private Long pid;
private String image;
private String pname;
private Double price;
private Long uid;
private String uname;
private String role;
private String apartment;
public Long getCid() {
return cid;
}
public void setCid(Long cid) {
this.cid = cid;
}
public Double getQuantity() {
return quantity;
}
public void setQuantity(Double quantity) {
this.quantity = quantity;
}
public Double getTotalPrice() {
return totalPrice;
}
public void setTotalPrice(Double totalPrice) {
this.totalPrice = totalPrice;
}
public Long getPid() {
return pid;
}
public void setPid(Long pid) {
this.pid = pid;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public String getPname() {
return pname;
}
public void setPname(String pname) {
this.pname = pname;
}
public Double getPrice() {
return price;
}
public void setPrice(Double price) {
this.price = price;
}
public Long getUid() {
return uid;
}
public void setUid(Long uid) {
this.uid = uid;
}
public String getUname() {
return uname;
}
public void setUname(String uname) {
this.uname = uname;
}
public String getRole() {
return role;
}
public void setRole(String role) {
this.role = role;
}
public String getApartment() {
return apartment;
}
public void setApartment(String apartment) {
this.apartment = apartment;
}
}

87
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Orderdto.java

@ -0,0 +1,87 @@
package com.myrestapp.demo.dto;
public class Orderdto {
private Long cid;
private Double quantity;
private Double totalPrice;
private Long pid;
private String image;
private String pname;
private Double price;
private Long uid;
private String uname;
private String role;
private String apartment;
public Long getCid() {
return cid;
}
public void setCid(Long cid) {
this.cid = cid;
}
public Double getQuantity() {
return quantity;
}
public void setQuantity(Double quantity) {
this.quantity = quantity;
}
public Double getTotalPrice() {
return totalPrice;
}
public void setTotalPrice(Double totalPrice) {
this.totalPrice = totalPrice;
}
public Long getPid() {
return pid;
}
public void setPid(Long pid) {
this.pid = pid;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public String getPname() {
return pname;
}
public void setPname(String pname) {
this.pname = pname;
}
public Double getPrice() {
return price;
}
public void setPrice(Double price) {
this.price = price;
}
public Long getUid() {
return uid;
}
public void setUid(Long uid) {
this.uid = uid;
}
public String getUname() {
return uname;
}
public void setUname(String uname) {
this.uname = uname;
}
public String getRole() {
return role;
}
public void setRole(String role) {
this.role = role;
}
public String getApartment() {
return apartment;
}
public void setApartment(String apartment) {
this.apartment = apartment;
}
}

77
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Cart.java

@ -0,0 +1,77 @@
package com.myrestapp.demo.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;
@Entity
public class Cart {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private Double quantity;
private Double totalPrice;
private Double subtotal;
public Double getSubtotal() {
return subtotal;
}
public void setSubtotal(Double subtotal) {
this.subtotal = subtotal;
}
@OneToOne
private User users;
@OneToOne
private Product product;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Double getQuantity() {
return quantity;
}
public void setQuantity(Double quantity) {
this.quantity = quantity ;
}
public Double getTotalPrice() {
return totalPrice;
}
public void setTotalPrice(Double totalPrice) {
this.totalPrice = totalPrice;
}
public User getUsers() {
return users;
}
public void setUsers(User users) {
this.users = users;
}
public Product getProduct() {
return product;
}
public void setProduct(Product product) {
this.product = product;
}
}

37
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Category.java

@ -0,0 +1,37 @@
package com.myrestapp.demo.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name = "category")
public class Category {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String name;
public Category() {
super();
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}

183
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Order.java

@ -0,0 +1,183 @@
package com.myrestapp.demo.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;
import javax.persistence.Table;
@Entity
@Table(name = "orderr")
public class Order {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private Long orderNumber;
private Double subtotal;
private Long cid;
private Double quantity;
private Double totalPrice;
private Long pid;
private String image;
private String pname;
private Double price;
private Long uid;
private String uname;
private String role;
private String apartment;
public Order(Long id, Long orderNumber, Double subtotal, Long cid, Double quantity, Double totalPrice, Long pid,
String image, String pname, Double price, Long uid, String uname, String role, String apartment) {
super();
this.id = id;
this.orderNumber = orderNumber;
this.subtotal = subtotal;
this.cid = cid;
this.quantity = quantity;
this.totalPrice = totalPrice;
this.pid = pid;
this.image = image;
this.pname = pname;
this.price = price;
this.uid = uid;
this.uname = uname;
this.role = role;
this.apartment = apartment;
}
public Order() {
super();
// TODO Auto-generated constructor stub
}
@Override
public String toString() {
return "Order [id=" + id + ", orderNumber=" + orderNumber + ", subtotal=" + subtotal + ", cid=" + cid
+ ", quantity=" + quantity + ", totalPrice=" + totalPrice + ", pid=" + pid + ", image=" + image
+ ", pname=" + pname + ", price=" + price + ", uid=" + uid + ", uname=" + uname + ", role=" + role
+ ", apartment=" + apartment + "]";
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public Long getOrderNumber() {
return orderNumber;
}
public void setOrderNumber(Long orderNumber) {
this.orderNumber = orderNumber;
}
public Double getSubtotal() {
return subtotal;
}
public void setSubtotal(Double subtotal) {
this.subtotal = subtotal;
}
public Long getCid() {
return cid;
}
public void setCid(Long cid) {
this.cid = cid;
}
public Double getQuantity() {
return quantity;
}
public void setQuantity(Double quantity) {
this.quantity = quantity;
}
public Double getTotalPrice() {
return totalPrice;
}
public void setTotalPrice(Double totalPrice) {
this.totalPrice = totalPrice;
}
public Long getPid() {
return pid;
}
public void setPid(Long pid) {
this.pid = pid;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public String getPname() {
return pname;
}
public void setPname(String pname) {
this.pname = pname;
}
public Double getPrice() {
return price;
}
public void setPrice(Double price) {
this.price = price;
}
public Long getUid() {
return uid;
}
public void setUid(Long uid) {
this.uid = uid;
}
public String getUname() {
return uname;
}
public void setUname(String uname) {
this.uname = uname;
}
public String getRole() {
return role;
}
public void setRole(String role) {
this.role = role;
}
public String getApartment() {
return apartment;
}
public void setApartment(String apartment) {
this.apartment = apartment;
}
}

59
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/OrderStatus.java

@ -0,0 +1,59 @@
package com.myrestapp.demo.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class OrderStatus {
private Order order;
private String status;// progress,completed
private String message;
public OrderStatus(Order order, String status, String message) {
super();
this.order = order;
this.status = status;
this.message = message;
}
public OrderStatus() {
super();
// TODO Auto-generated constructor stub
}
public Order getOrder() {
return order;
}
public void setOrder(Order order) {
this.order = order;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
@Override
public String toString() {
return "OrderStatus [order=" + order + ", status=" + status + ", message=" + message + "]";
}
}

81
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Product.java

@ -0,0 +1,81 @@
package com.myrestapp.demo.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;
import com.myrestapp.demo.model.Category;
@Entity
public class Product {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String name;
private Double price;
private Double rating;
private String image;
@OneToOne
private Category category;
public Product() {
super();
// TODO Auto-generated constructor stub
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Double getPrice() {
return price;
}
public void setPrice(Double price) {
this.price = price;
}
public Double getRating() {
return rating;
}
public void setRating(Double rating) {
this.rating = rating;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public Category getCategory() {
return category;
}
public void setCategory(Category category) {
this.category = category;
}
}

117
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/User.java

@ -0,0 +1,117 @@
package com.myrestapp.demo.model;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;
@Entity
public class User implements UserDetails{
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String name;
private String username;
private String password;
private String role;
private String apartment;
public String getApartment() {
return apartment;
}
public void setApartment(String apartment) {
this.apartment = apartment;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getRole() {
return role;
}
public void setRole(String role) {
this.role = role;
}
@Override
public Collection<? extends GrantedAuthority> getAuthorities() {
List<GrantedAuthority> list = new ArrayList<>();
SimpleGrantedAuthority sga = new SimpleGrantedAuthority(role);
list.add(sga);
return list;
}
//account will not get expired
@Override
public boolean isAccountNonExpired() {
return true;
}
//account will not get locked
@Override
public boolean isAccountNonLocked() {
return true;
}
//login credentials will not get expired
@Override
public boolean isCredentialsNonExpired() {
return true;
}
//enabled to login
@Override
public boolean isEnabled() {
return true;
}
}

32
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/publisher/OrderPublisher.java

@ -0,0 +1,32 @@
package com.myrestapp.demo.publisher;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.myrestapp.demo.config.MessagingConfig;
import com.myrestapp.demo.model.Order;
import com.myrestapp.demo.model.OrderStatus;
@RestController
@RequestMapping("/orderrbt")
public class OrderPublisher {
/*@Autowired
private RabbitTemplate template;
@PostMapping("/{restaurantName}")
public String bookOrder(@RequestBody Order order, @PathVariable String restaurantName) {
//order.setId(UUID.randomUUID().toString());
//restaurantservice
//payment service
OrderStatus orderStatus = new OrderStatus(order, "PROCESS", "order placed succesfully in " + restaurantName);
template.convertAndSend(MessagingConfig.EXCHANGE, MessagingConfig.ROUTING_KEY, orderStatus);
return "Success !!";
}*/
}

26
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CartRepository.java

@ -0,0 +1,26 @@
package com.myrestapp.demo.repository;
import java.util.List;
import javax.transaction.Transactional;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import com.myrestapp.demo.model.Cart;
public interface CartRepository extends JpaRepository<Cart, Long> {
@Query("select c from Cart c join c.users u where u.id=?1")
List<Cart> getCartByUserId(Long uid);
@Modifying
@Transactional
@Query("delete from Cart c where c.users.id=?1")
public void deleteAll(Long uid);
}

9
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CategoryRepository.java

@ -0,0 +1,9 @@
package com.myrestapp.demo.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import com.myrestapp.demo.model.Category;
public interface CategoryRepository extends JpaRepository<Category, Long>{
}

19
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/OrderRepository.java

@ -0,0 +1,19 @@
package com.myrestapp.demo.repository;
import java.util.List;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import com.myrestapp.demo.model.Order;
public interface OrderRepository extends JpaRepository<Order, Long>{
@Query(value="select * from orderr as o where o.uid=?1 order by o.order_number ASC",nativeQuery=true)
List<Order> findByCustomerId(Long uid);
}

15
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/ProductRepository.java

@ -0,0 +1,15 @@
package com.myrestapp.demo.repository;
import java.util.List;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import com.myrestapp.demo.model.Product;
public interface ProductRepository extends JpaRepository<Product, Long>{
@Query("select p from Product p join p.category c where c.name=?1")
List<Product> getProductsByCategory(String categoryName);
}

20
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/UserRepository.java

@ -0,0 +1,20 @@
package com.myrestapp.demo.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import com.myrestapp.demo.model.User;
public interface UserRepository extends JpaRepository<User, Long> {
@Query("select u from User u where u.username=?1")
User getByUsername(String username);
@Query("select u.id from User u where u.username=?1")
Long getIdByUsername(String username);
@Query("select u from User u where u.username=?1")
User getByUserName(String username);
}

23
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/CartService.java

@ -0,0 +1,23 @@
package com.myrestapp.demo.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.myrestapp.demo.model.Cart;
import com.myrestapp.demo.model.Product;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.CartRepository;
import com.myrestapp.demo.repository.ProductRepository;
@Service
public class CartService {
@Autowired
private ProductRepository productRepository;
@Autowired
private CartRepository cartRepository;
}

27
BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/MyUserDetailsService.java

@ -0,0 +1,27 @@
package com.myrestapp.demo.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.UserRepository;
@Service
public class MyUserDetailsService implements UserDetailsService{
@Autowired
UserRepository userRepository;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
User user = userRepository.getByUsername(username);
return user;
}
}

16
BackEnd/DailyCart_DD/src/main/resources/application.properties

@ -0,0 +1,16 @@
server.port=1005
spring.datasource.url=jdbc:mysql://localhost:3306/DailyCart?createDatabaseIfNotExist=true
spring.datasource.username=root
spring.datasource.password=Password123
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
spring.jpa.hibernate.ddl-auto=update
spring.jackson.serialization.fail-on-empty-beans=false
server.servlet.context-path=/api1
spring.rabbitmq.host=labs4.koteshwar.com
spring.rabbitmq.password=guest
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest

19
BackEnd/DailyCart_DD/src/test/java/com/myrestapp/demo/DailyCartDdApplicationTests.java

@ -0,0 +1,19 @@
package com.myrestapp.demo;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import com.myrestapp.demo.model.User;
import com.myrestapp.demo.repository.UserRepository;
@SpringBootTest
class DailyCartDdApplicationTests {
@Test
void contextLoads() {
}
}

17
FrontEnd/.browserslistrc

@ -0,0 +1,17 @@
# This file is used by the build system to adjust CSS and JS output to support the specified browsers below.
# For additional information regarding the format and rule options, please see:
# https://github.com/browserslist/browserslist#queries
# For the full list of supported browsers by the Angular framework, please see:
# https://angular.io/guide/browser-support
# You can see what browsers were selected by your queries by running:
# npx browserslist
last 1 Chrome version
last 1 Firefox version
last 2 Edge major versions
last 2 Safari major versions
last 2 iOS major versions
Firefox ESR
not IE 11 # Angular supports IE 11 only as an opt-in. To opt-in, remove the 'not' prefix on this line.

16
FrontEnd/.editorconfig

@ -0,0 +1,16 @@
# Editor configuration, see https://editorconfig.org
root = true
[*]
charset = utf-8
indent_style = space
indent_size = 2
insert_final_newline = true
trim_trailing_whitespace = true
[*.ts]
quote_type = single
[*.md]
max_line_length = off
trim_trailing_whitespace = false

45
FrontEnd/.gitignore

@ -0,0 +1,45 @@
# See http://help.github.com/ignore-files/ for more about ignoring files.
# compiled output
/dist
/tmp
/out-tsc
# Only exists if Bazel was run
/bazel-out
# dependencies
/node_modules
# profiling files
chrome-profiler-events*.json
# IDEs and editors
/.idea
.project
.classpath
.c9/
*.launch
.settings/
*.sublime-workspace
# IDE - VSCode
.vscode/*
!.vscode/settings.json
!.vscode/tasks.json
!.vscode/launch.json
!.vscode/extensions.json
.history/*
# misc
/.sass-cache
/connect.lock
/coverage
/libpeerconnection.log
npm-debug.log
yarn-error.log
testem.log
/typings
# System Files
.DS_Store
Thumbs.db

27
FrontEnd/README.md

@ -0,0 +1,27 @@
# DailyCart
This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.2.1.
## Development server
Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files.
## Code scaffolding
Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`.
## Build
Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory.
## Running unit tests
Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io).
## Running end-to-end tests
Run `ng e2e` to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities.
## Further help
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.

109
FrontEnd/angular.json

@ -0,0 +1,109 @@
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"version": 1,
"newProjectRoot": "projects",
"projects": {
"DailyCart": {
"projectType": "application",
"schematics": {
"@schematics/angular:application": {
"strict": true
}
},
"root": "",
"sourceRoot": "src",
"prefix": "app",
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
"outputPath": "dist/DailyCart",
"index": "src/index.html",
"main": "src/main.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.app.json",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": [
"node_modules/jquery/dist/jquery.min.js",
"src/assets/js/main.js"
]
},
"configurations": {
"production": {
"budgets": [
{
"type": "initial",
"maximumWarning": "500kb",
"maximumError": "1mb"
},
{
"type": "anyComponentStyle",
"maximumWarning": "2kb",
"maximumError": "4kb"
}
],
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"outputHashing": "all"
},
"development": {
"buildOptimizer": false,
"optimization": false,
"vendorChunk": true,
"extractLicenses": false,
"sourceMap": true,
"namedChunks": true
}
},
"defaultConfiguration": "production"
},
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"configurations": {
"production": {
"browserTarget": "DailyCart:build:production"
},
"development": {
"browserTarget": "DailyCart:build:development"
}
},
"defaultConfiguration": "development"
},
"extract-i18n": {
"builder": "@angular-devkit/build-angular:extract-i18n",
"options": {
"browserTarget": "DailyCart:build"
}
},
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"main": "src/test.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.spec.json",
"karmaConfig": "karma.conf.js",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": []
}
}
}
}
},
"defaultProject": "DailyCart"
}

44
FrontEnd/karma.conf.js

@ -0,0 +1,44 @@
// Karma configuration file, see link for more information
// https://karma-runner.github.io/1.0/config/configuration-file.html
module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', '@angular-devkit/build-angular'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-jasmine-html-reporter'),
require('karma-coverage'),
require('@angular-devkit/build-angular/plugins/karma')
],
client: {
jasmine: {
// you can add configuration options for Jasmine here
// the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
// for example, you can disable the random execution with `random: false`
// or set a specific seed with `seed: 4321`
},
clearContext: false // leave Jasmine Spec Runner output visible in browser
},
jasmineHtmlReporter: {
suppressAll: true // removes the duplicated traces
},
coverageReporter: {
dir: require('path').join(__dirname, './coverage/DailyCart'),
subdir: '.',
reporters: [
{ type: 'html' },
{ type: 'text-summary' }
]
},
reporters: ['progress', 'kjhtml'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false,
restartOnFileChange: true
});
};

12104
FrontEnd/package-lock.json
File diff suppressed because it is too large
View File

40
FrontEnd/package.json

@ -0,0 +1,40 @@
{
"name": "daily-cart",
"version": "0.0.0",
"scripts": {
"ng": "ng",
"start": "ng serve --port 8001 --proxy-config proxy.config.json",
"build": "ng build",
"watch": "ng build --watch --configuration development",
"test": "ng test"
},
"private": true,
"dependencies": {
"@angular/animations": "~12.2.0",
"@angular/common": "~12.2.0",
"@angular/compiler": "~12.2.0",
"@angular/core": "~12.2.0",
"@angular/forms": "~12.2.0",
"@angular/platform-browser": "~12.2.0",
"@angular/platform-browser-dynamic": "~12.2.0",
"@angular/router": "~12.2.0",
"jquery": "^3.6.0",
"rxjs": "~6.6.0",
"tslib": "^2.3.0",
"zone.js": "~0.11.4"
},
"devDependencies": {
"@angular-devkit/build-angular": "~12.2.1",
"@angular/cli": "~12.2.1",
"@angular/compiler-cli": "~12.2.0",
"@types/jasmine": "~3.8.0",
"@types/node": "^12.11.1",
"jasmine-core": "~3.8.0",
"karma": "~6.3.0",
"karma-chrome-launcher": "~3.1.0",
"karma-coverage": "~2.0.3",
"karma-jasmine": "~4.0.0",
"karma-jasmine-html-reporter": "~1.7.0",
"typescript": "~4.3.5"
}
}

6
FrontEnd/proxy.config.json

@ -0,0 +1,6 @@
{
"/api1/*" :{
"target" : "http://localhost:1005",
"secure" : false
}
}

BIN
FrontEnd/src/1.jpg

Before After
Width: 1200  |  Height: 800  |  Size: 88 KiB

754
FrontEnd/src/10.htm
File diff suppressed because it is too large
View File

BIN
FrontEnd/src/11.png

Before After
Width: 840  |  Height: 650  |  Size: 253 KiB

BIN
FrontEnd/src/2.jpg

Before After
Width: 626  |  Height: 417  |  Size: 13 KiB

BIN
FrontEnd/src/3.jpg

Before After
Width: 616  |  Height: 280  |  Size: 56 KiB

BIN
FrontEnd/src/4.png

Before After
Width: 241  |  Height: 209  |  Size: 143 B

BIN
FrontEnd/src/5.png

Before After
Width: 275  |  Height: 183  |  Size: 143 B

BIN
FrontEnd/src/6.png

Before After
Width: 500  |  Height: 500  |  Size: 153 KiB

BIN
FrontEnd/src/7.jpg

Before After
Width: 238  |  Height: 250  |  Size: 7.0 KiB

BIN
FrontEnd/src/8.png

Before After
Width: 860  |  Height: 887  |  Size: 30 KiB

BIN
FrontEnd/src/9.png

Before After
Width: 820  |  Height: 431  |  Size: 13 KiB

38
FrontEnd/src/app/app-routing.module.ts

@ -0,0 +1,38 @@
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { LoginComponent } from './auth/login/login.component';
import { AuthGuardService } from './auth/service/auth-guard.service';
import { SignupComponent } from './auth/signup/signup.component';
import { BannerComponent } from './components/banner/banner.component';
import { CartComponent } from './components/cart/cart.component';
import { DairyComponent } from './components/dairy/dairy.component';
import { FruitsComponent } from './components/fruits/fruits.component';
import { HouseholdComponent } from './components/household/household.component';
import { OrderComponent } from './components/order/order.component';
import { PaymentComponent } from './components/payment/payment.component';
import { ProductsComponent } from './components/products/products.component';
import { ProfileComponent } from './components/profile/profile.component';
import { SnacksComponent } from './components/snacks/snacks.component';
import { WholegrainComponent } from './components/wholegrain/wholegrain.component';
const routes: Routes = [
{path:'products', component:ProductsComponent, canActivate : [AuthGuardService] },
{path:'cart', component:CartComponent, canActivate : [AuthGuardService] },
{path:'profile/:uid', component:ProfileComponent, canActivate : [AuthGuardService] },
{path:'products/fruits', component:FruitsComponent},
{path:'products/dairy', component:DairyComponent},
{path:'products/household', component:HouseholdComponent},
{path:'products/wholegrain', component:WholegrainComponent},
{path:'products/snacks', component:SnacksComponent},
{path:'login', component:LoginComponent},
{path:'signup', component:SignupComponent},
{path:'banner', component:BannerComponent},
{path:'order', component:OrderComponent, canActivate : [AuthGuardService]},
{path:'payment', component:PaymentComponent}
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }

0
FrontEnd/src/app/app.component.css

32
FrontEnd/src/app/app.component.html

@ -0,0 +1,32 @@
<style>
body {
background-image: url('1.jpg');
background-position: center;
background-size: cover;
}
</style>
<!DOCTYPE html>
<html lang="en">
<head>
<title>DailyCart</title>
</head>
<body>
<h2 class="logo">DailyCart</h2>
<div class="menu">
<ul>
<li><a routerLink="banner">HOME</a></li>
<li><a routerLink="products">PRODUCTS</a></li>
<li><a routerLink="cart">CART</a></li>
<li><a routerLink="order">ORDERS</a></li>
<li><a (click)="onProfile()">PROFILE</a></li>
</ul>
</div>
<div class="search">
<input class="srch" type="search" name="" placeholder="Search here...">
<a routerLink="products"> <button class="btn">Search</button></a>
</div>
</body>
</html>
<router-outlet></router-outlet>

35
FrontEnd/src/app/app.component.spec.ts

@ -0,0 +1,35 @@
import { TestBed } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [
RouterTestingModule
],
declarations: [
AppComponent
],
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
it(`should have as title 'DailyCart'`, () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app.title).toEqual('DailyCart');
});
it('should render title', () => {
const fixture = TestBed.createComponent(AppComponent);
fixture.detectChanges();
const compiled = fixture.nativeElement as HTMLElement;
expect(compiled.querySelector('.content span')?.textContent).toContain('DailyCart app is running!');
});
});

30
FrontEnd/src/app/app.component.ts

@ -0,0 +1,30 @@
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import { UserService } from './auth/service/user.service';
import { ProductsService } from './service/products.service';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit{
title = 'DailyCart';
username:any;
uid!:any;
constructor(private route : Router,private productService : ProductsService,private userService : UserService)
{
}
ngOnInit(): void {
}
onProfile(){
this.uid = window.sessionStorage.getItem('userid');
this.route.navigateByUrl('/profile/'+this.uid);
}
}

52
FrontEnd/src/app/app.module.ts

@ -0,0 +1,52 @@
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { ProductsComponent } from './components/products/products.component';
import { ReactiveFormsModule } from '@angular/forms';
import {HttpClientModule} from '@angular/common/http';
import { CategoryComponent } from './components/category/category.component';
import { CartComponent } from './components/cart/cart.component';
import { FruitsComponent } from './components/fruits/fruits.component';
import { DairyComponent } from './components/dairy/dairy.component';
import { WholegrainComponent } from './components/wholegrain/wholegrain.component';
import { HouseholdComponent } from './components/household/household.component';
import { SnacksComponent } from './components/snacks/snacks.component';
import { LoginComponent } from './auth/login/login.component';
import { BannerComponent } from './components/banner/banner.component';
import { ProfileComponent } from './components/profile/profile.component';
import { SignupComponent } from './auth/signup/signup.component';
import { OrderComponent } from './components/order/order.component';
import { PaymentComponent } from './components/payment/payment.component';
@NgModule({
declarations: [
AppComponent,
ProductsComponent,
CategoryComponent,
CartComponent,
FruitsComponent,
DairyComponent,
WholegrainComponent,
HouseholdComponent,
SnacksComponent,
LoginComponent,
BannerComponent,
ProfileComponent,
SignupComponent,
OrderComponent,
PaymentComponent
],
imports: [
BrowserModule,
AppRoutingModule,
ReactiveFormsModule,
HttpClientModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }

0
FrontEnd/src/app/auth/login/login.component.css

108
FrontEnd/src/app/auth/login/login.component.html

@ -0,0 +1,108 @@
<Style>
a {
text-decoration: none;
font-size: 17px;
color: black;
}
body
{
margin: 0;
padding: 0;
font-family: 'Arial';
}
.login{
width: 382px;
overflow: hidden;
margin: auto;
margin: 20 0 0 450px;
padding: 40px;
background: #6abadeba;
border-radius: 15px ;
}
h2{
color: #ff7200;
padding: 20px;
}
label{
color: black;
font-size: 17px;
}
#Uname{
width: 300px;
height: 30px;
border: none;
border-radius: 3px;
padding-left: 8px;
}
#Pass{
width: 300px;
height: 30px;
border: none;
border-radius: 3px;
padding-left: 8px;
}
#log{
width: 300px;
height: 30px;
border: none;
border-radius: 17px;
padding-left: 7px;
color: #ff7200;
}
span{
color: white;
font-size: 17px;
}
a{
float: right;
background-color: grey;
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</Style>
<!DOCTYPE html>
<html>
<head>
<title>Login Form</title>
</head>
<body>
<div class="banner">
<br><br><br><br><br><br>
<div class="login">
<form id="login" method="get" action="login.php" [formGroup]='loginForm' (submit)='OnLoginFormSubmit()'>
<h2 class="logo">Login to DailyCart</h2><br><br><br><br><br>
<label><b>Username <br>
</b>
</label>
<input type="text" id="Uname" formControlName="username">
<br><br>
<label><b>Password
</b>
</label>
<input type="password" id="Pass" formControlName="password">
<br><br><br>
<button [disabled]="!loginForm.valid" id="log"> LOGIN </button>
<br><br>
<p>New User?<a href="signup"><img border="0" src="https://previews.123rf.com/images/faysalfarhan/faysalfarhan1711/faysalfarhan171137973/89544623-sign-up-member-icon-isolated-on-elegant-yellow-round-button-abstract-illustration.jpg" width="70" height="70"></a></p>
</form>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br>
</div>
</body>
</html>
<router-outlet></router-outlet>

25
FrontEnd/src/app/auth/login/login.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { LoginComponent } from './login.component';
describe('LoginComponent', () => {
let component: LoginComponent;
let fixture: ComponentFixture<LoginComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ LoginComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(LoginComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

53
FrontEnd/src/app/auth/login/login.component.ts

@ -0,0 +1,53 @@
import { Component, OnInit } from '@angular/core';
import { FormControl, FormGroup, Validators } from '@angular/forms';
import { Router } from '@angular/router';
import { User } from 'src/app/model/User';
import { ProductsService } from 'src/app/service/products.service';
import { UserService } from '../service/user.service';
@Component({
selector: 'app-login',
templateUrl: './login.component.html',
styleUrls: ['./login.component.css']
})
export class LoginComponent implements OnInit {
loginForm! : FormGroup;
user! : User
msg: string;
uid!:any;
constructor(private route: Router,private userService:UserService, private productService:ProductsService)
{
this.msg='';
}
ngOnInit(): void {
this.loginForm = new FormGroup({
username : new FormControl('', Validators.required),
password : new FormControl('', Validators.required)
});
}
OnLoginFormSubmit()
{
this.user = {
username : this.loginForm.value.username,
role : this.loginForm.value.role,
password : this.loginForm.value.password
}
this.userService.login(this.user).subscribe((data: any)=>{
//save the username and password in local storage
window.sessionStorage.setItem("username",this.user.username);
window.sessionStorage.setItem("isLoggedIn","true");
this.route.navigateByUrl('/banner');
}),
(err: any)=>{
this.msg='Invalid credentials...Check your Login and Password!!!';
window.sessionStorage.removeItem("username");
window.sessionStorage.removeItem("isLoggedIn");
};
}
}

16
FrontEnd/src/app/auth/service/auth-guard.service.spec.ts

@ -0,0 +1,16 @@
import { TestBed } from '@angular/core/testing';
import { AuthGuardService } from './auth-guard.service';
describe('AuthGuardService', () => {
let service: AuthGuardService;
beforeEach(() => {
TestBed.configureTestingModule({});
service = TestBed.inject(AuthGuardService);
});
it('should be created', () => {
expect(service).toBeTruthy();
});
});

21
FrontEnd/src/app/auth/service/auth-guard.service.ts

@ -0,0 +1,21 @@
import { Injectable } from '@angular/core';
import { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot } from '@angular/router';
import { AuthService } from './auth.service';
@Injectable({
providedIn: 'root'
})
export class AuthGuardService implements CanActivate {
status! : boolean;
constructor(private authService : AuthService, private route : Router ) { }
canActivate(route : ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean{
this.status = this.authService.isAuthenticated();
if(this.status == false){
this.route.navigateByUrl('login');
}
return true;
}
}

16
FrontEnd/src/app/auth/service/auth.service.spec.ts

@ -0,0 +1,16 @@
import { TestBed } from '@angular/core/testing';
import { AuthService } from './auth.service';
describe('AuthService', () => {
let service: AuthService;
beforeEach(() => {
TestBed.configureTestingModule({});
service = TestBed.inject(AuthService);
});
it('should be created', () => {
expect(service).toBeTruthy();
});
});

22
FrontEnd/src/app/auth/service/auth.service.ts

@ -0,0 +1,22 @@
import { Injectable } from '@angular/core';
import { User } from 'src/app/model/User';
@Injectable({
providedIn: 'root'
})
export class AuthService {
user: User = new User();
constructor() {
}
isAuthenticated() : boolean{
this.user.username = window.sessionStorage.getItem('username');
let isLoggedIn = window.sessionStorage.getItem('isLoggedIn');
if(isLoggedIn == 'true')
return true;
else
return false;
}
}

41
FrontEnd/src/app/auth/service/user.service.ts

@ -0,0 +1,41 @@
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs';
import { User } from 'src/app/model/User';
@Injectable({
providedIn: 'root'
})
export class UserService {
path:string='http://localhost:8001/api1';
constructor(private httpClient:HttpClient){
}
postUser(user : User):Observable<User[]>{
let authCode = btoa(user.username+':'+user.password);
user.username = authCode;
user.password = '';
return this.httpClient.post<User[]>(this.path+'/signup/',user);
}
login(user : any):Observable<User[]>{
let httpOptions={
headers : new HttpHeaders({
'Content-Type':'application/json',
'Authorization':'Basic ' + btoa(user.username+':'+user.password)
})
}
window.sessionStorage.setItem("code",btoa(user.username+':'+user.password));
let login_api = this.path + '/login';
return this.httpClient.get<User[]>(login_api,httpOptions);
}
public getDetails(user:any):Observable<User>{
console.log("j",user)
let user_api=this.path+'/username/'+user;
return this.httpClient.get<any>(user_api);
}
}

0
FrontEnd/src/app/auth/signup/signup.component.css

125
FrontEnd/src/app/auth/signup/signup.component.html

@ -0,0 +1,125 @@
<Style>
body
{
margin: 0;
padding: 0;
font-family: 'Arial';
}
.login{
width: 382px;
overflow: hidden;
margin: auto;
margin: 20 0 0 450px;
padding: 32px;
background: #6abadeba;
border-radius: 15px ;
}
h2{
color: #ff7200;
padding: 20px;
}
label{
color: black;
font-size: 17px;
}
#Uname{
width: 300px;
height: 30px;
border: none;
border-radius: 3px;
padding-left: 8px;
}
#Pass{
width: 300px;
height: 30px;
border: none;
border-radius: 3px;
padding-left: 8px;
}
#log{
width: 300px;
height: 30px;
border: none;
border-radius: 17px;
padding-left: 7px;
color: #ff7200;
}
span{
color: white;
font-size: 17px;
}
a{
float: right;
background-color: grey;
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</Style>
<!DOCTYPE html>
<html>
<head>
<title>Login Form</title>
</head>
<body>
<div class="banner">
<br><br><br><br><br><br>
<div class="login">
<form id="login" method="get" action="login.php" [formGroup]='signUpForm' (submit)='onSignUpFormSubmit()'>
<h2 class="logo">Sign Up to DailyCart</h2><br><br><br><br><br>
<label><b>Name <br>
</b>
</label>
<input type="text" id="Uname" formControlName="name">
<br><br>
<label><b>Username <br>
</b>
</label>
<input type="text" id="Uname" formControlName="username">
<br><br>
<label><b>Role <br>
</b>
</label>
<select name="role" id="Uname" formControlName="role">
<option value="Admin">Admin</option>
<option value="User">User</option>
</select>
<br><br>
<label><b>Apartment <br>
</b>
</label>
<select name="apartment" id="Uname" formControlName="apartment">
<option value="Apartment 1">Apartment 1</option>
<option value="Apartment 2">Apartment 2</option>
<option value="Apartment 3">Apartment 3</option>
<option value="Apartment 4">Apartment 4</option>
</select>
<br><br>
<label><b>Password <br>
</b>
</label>
<input type="password" id="Pass" formControlName="password">
<br><br> <br>
<button [disabled]="!signUpForm.valid" id="log"> SIGN IN </button>
<br><br>
</form>
</div>
<br><br><br><br> <br><br> <br><br> <br><br>
</div>
</body>
</html>

25
FrontEnd/src/app/auth/signup/signup.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { SignupComponent } from './signup.component';
describe('SignupComponent', () => {
let component: SignupComponent;
let fixture: ComponentFixture<SignupComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ SignupComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(SignupComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

45
FrontEnd/src/app/auth/signup/signup.component.ts

@ -0,0 +1,45 @@
import { Component, OnInit } from '@angular/core';
import { FormControl, FormGroup, Validators } from '@angular/forms';
import { Router } from '@angular/router';
import { User } from 'src/app/model/User';
import { UserService } from '../service/user.service';
@Component({
selector: 'app-signup',
templateUrl: './signup.component.html',
styleUrls: ['./signup.component.css']
})
export class SignupComponent implements OnInit {
signUpForm! : FormGroup;
constructor(private route: Router, private userService:UserService)
{
}
ngOnInit(): void {
this.signUpForm = new FormGroup({
name : new FormControl('',[Validators.required]),
username : new FormControl('',[Validators.required]),
password : new FormControl('',[Validators.required]),
role : new FormControl('',[Validators.required]),
apartment : new FormControl('',[Validators.required])
});
}
onSignUpFormSubmit() : void{
let user : User={
name : this.signUpForm.value.name,
username : this.signUpForm.value.username,
password : this.signUpForm.value.password,
role : this.signUpForm.value.role,
apartment : this.signUpForm.value.apartment
};
this.userService.postUser(user).subscribe(
(data: any)=>{this.route.navigateByUrl('/login');},
(err: any)=>{console.log(err)}
);
}
}

0
FrontEnd/src/app/components/banner/banner.component.css

19
FrontEnd/src/app/components/banner/banner.component.html

@ -0,0 +1,19 @@
<style>
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</style>
<div class="banner">
<br><br><br>
<div class="content">
<h1><span>Welcome to DailyCart</span><br>-Team Seattle<br> </h1>
<img src="https://www.pngall.com/wp-content/uploads/4/Grocery-PNG-Picture.png" style="width:40%">
</div>
<br><br><br><br>
</div>

25
FrontEnd/src/app/components/banner/banner.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { BannerComponent } from './banner.component';
describe('BannerComponent', () => {
let component: BannerComponent;
let fixture: ComponentFixture<BannerComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ BannerComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(BannerComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

29
FrontEnd/src/app/components/banner/banner.component.ts

@ -0,0 +1,29 @@
import { Component, OnInit } from '@angular/core';
import { UserService } from 'src/app/auth/service/user.service';
@Component({
selector: 'app-banner',
templateUrl: './banner.component.html',
styleUrls: ['./banner.component.css']
})
export class BannerComponent implements OnInit {
constructor(private userService:UserService) { }
ngOnInit(): void {
console.log(window.location.pathname)
this.userService.getDetails(window.sessionStorage.getItem("username")).subscribe(data => {
window.sessionStorage.setItem('userid', String(data.id));
console.log("j",data.id)
});
this.userService.getDetails(window.sessionStorage.getItem("username")).subscribe(data => {
window.sessionStorage.setItem('apartment', String(data.apartment));
console.log("j",data.apartment)
});
this.userService.getDetails(window.sessionStorage.getItem("username")).subscribe(data => {
window.sessionStorage.setItem('role', String(data.role));
console.log("j",data.role)
});
}
}

16
FrontEnd/src/app/components/cart/cart.component.css

@ -0,0 +1,16 @@
.item {
display: flex;
align-items: center;
flex-wrap: wrap;
}
.btn-pay {
background-color: #C800Da;
border: 0;
color: #fff;
font-weight: 600;
}
.fa-ticket {
color: #0e1fa1;
}

278
FrontEnd/src/app/components/cart/cart.component.html

@ -0,0 +1,278 @@
<style>
*{
box-sizing: border-box;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
}
body{
font-family: Helvetica;
-webkit-font-smoothing: antialiased;
background: rgba( 71, 147, 227, 1);
}
h2{
text-align: center;
font-size: 18px;
text-transform: uppercase;
letter-spacing: 1px;
color: white;
padding: 30px 0;
}
/* Table Styles */
.table-wrapper{
margin: 10px 70px 70px;
box-shadow: 0px 35px 50px rgba( 0, 0, 0, 0.2 );
}
.fl-table {
border-radius: 5px;
font-size: 16px;
font-weight: normal;
border: none;
border-collapse: collapse;
width: 100%;
max-width: 100%;
white-space: nowrap;
background-color: white;
}
.fl-table td, .fl-table th {
text-align: center;
padding: 8px;
}
.fl-table td {
border-right: 1px solid #f8f8f8;
font-size: 12px;
}
.fl-table thead th {
color: #ffffff;
background: #4FC3A1;
}
.fl-table thead th:nth-child(odd) {
color: #ffffff;
background: #324960;
}
.fl-table tr:nth-child(even) {
background: #F8F8F8;
}
/* Responsive */
@media (max-width: 767px) {
.fl-table {
display: block;
width: 100%;
}
.table-wrapper:before{
content: "Scroll horizontally >";
display: block;
text-align: right;
font-size: 11px;
color: white;
padding: 0 0 10px;
}
.fl-table thead, .fl-table tbody, .fl-table thead th {
display: block;
}
.fl-table thead th:last-child{
border-bottom: none;
}
.fl-table thead {
float: left;
}
.fl-table tbody {
position: relative;
overflow-x: auto;
}
.fl-table td, .fl-table th {
padding: 20px .625em .625em .625em;
height: 60px;
vertical-align: middle;
box-sizing: border-box;
overflow-x: hidden;
overflow-y: auto;
width: 120px;
font-size: 16px;
text-overflow: ellipsis;
}
.fl-table thead th {
text-align: left;
border-bottom: 1px solid #f7f7f9;
}
.fl-table tbody tr {
display: table-cell;
}
.fl-table tbody tr:nth-child(odd) {
background: none;
}
.fl-table tr:nth-child(even) {
background: transparent;
}
.fl-table tr td:nth-child(odd) {
background: #F8F8F8;
border-right: 1px solid #E6E4E4;
}
.fl-table tr td:nth-child(even) {
border-right: 1px solid #E6E4E4;
}
.fl-table tbody td {
display: block;
text-align: center;
}
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
.banner1 {
/* The image used */
background-image:
url(9.png);
background-position: center;
background-size: cover;
}
.quantity {
display: flex;
justify-content: center;
}
.quantity button {
width: 35px;
height: 35px;
border: 1px solid #000;
color: #000;
border-radius: 0;
background: #fff
}
.quantity input {
border: none;
border-top: 1px solid #000;
border-bottom: 1px solid #000;
text-align: center;
width: 100px;
font-size: 20px;
color: #000;
font-weight: 300;
}
.total-price {
text-align: center;
font-size: 30px;
color: black;
}
.total-price .fa-rupee {
display: inline-block;
font-size: 90%;
margin-right: 5px;
}
@import url('https://fonts.googleapis.com/css?family=Lato:400,700,900|Open+Sans:300,400|Oswald:400,700');
* {
padding: 0;
margin: 0;
box-sizing: border-box;
font-family: 'Lato', sans-serif;
font-weight: normal;
}
.item {
display: flex;
align-items: center;
flex-wrap: wrap;
}
.btn-pay {
background-color: #C800Da;
border: 0;
color: #fff;
font-weight: 600;
}
.fa-ticket {
color: #0e1fa1;
}
</style>
<!doctype html>
<html lang="en">
<div class="banner">
<br><br><br><br><br>
<ng-container *ngIf="role=='User'">
</ng-container>
<ng-container *ngIf="cartdto.length!=0">
<div class="table-wrapper">
<table class="fl-table">
<thead>
<tr>
<th>S NO.</th>
<th>IMAGE</th>
<th>PRODUCT NAME</th>
<th>PRICE</th>
<th>QUANTITY</th>
<th>TOTAL</th>
<th>REMOVE</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let i of cartdto; let in=index;">
<td>{{in+1}}</td>
<td><img src="{{i.image}}" style="width:80px"></td>
<td>{{i.pname}}</td>
<td><span id="price">{{i.price}}</span></td>
<td><button (click)="dec(i,i.cid)">-</button>{{i.quantity}}<button (click)="inc(i,i.cid)">+</button></td>
<td><b>₹ {{i.quantity*i.price}}</b></td>
<td><button (click)=removeItem(i.cid)>REMOVE</button></td>
</tr>
<tr>
<td colspan="4"></td>
<td><button routerLink="/products">SHOP MORE</button></td>
<td><button routerLink="/payment">PROCEED TO PAYMENT</button></td>
<td><strong>Grand Total : ₹ {{grandTotal1}}</strong></td>
</tr>
<tbody>
</table>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</ng-container>
<ng-container *ngIf="cartdto.length==0">
<div class="banner1">
<br>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<img src="http://www.shitalexports.com/img/empty-cart.jpg" style="width:40%">
</div>
<br><br><br><br><br><br><br><br><br>
</ng-container>
</div>
</html>

25
FrontEnd/src/app/components/cart/cart.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { CartComponent } from './cart.component';
describe('CartComponent', () => {
let component: CartComponent;
let fixture: ComponentFixture<CartComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ CartComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(CartComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

139
FrontEnd/src/app/components/cart/cart.component.ts

@ -0,0 +1,139 @@
import { Component, OnInit } from '@angular/core';
import { FormGroup } from '@angular/forms';
import { Cartdto } from 'src/app/model/Cartdto';
import { CartItem } from 'src/app/model/CartItem';
import { Orderdto } from 'src/app/model/Orderdto';
import { CartService } from 'src/app/service/cart.service';
declare const calc:any
@Component({
selector: 'app-cart',
templateUrl: './cart.component.html',
styleUrls: ['./cart.component.css']
})
export class CartComponent implements OnInit {
public products : any = [];
cartItem!:CartItem[];
cartdto!:Cartdto[];
orderdto!:Orderdto[];
cartdto2!:Cartdto[];
uid!:any;
pid!:any;
cid!:any;
oid!:any;
role!:any;
public grandTotal : number = 0;
public grandTotal1 : any;
qty!:any;
qty1!:any;
cartForm!:FormGroup
constructor(private cartService:CartService) {
}
ngOnInit(): void {
this.cartService.getProducts().subscribe(res=>{
this.products = res;
this.grandTotal = this.cartService.getTotalPrice();
})
this.role = window.sessionStorage.getItem('role');
console.log(this.role);
this.uid = window.sessionStorage.getItem('userid');
this.cartService.getCartdto(this.uid).subscribe(res=>{
this.cartdto=res;
})
this.uid = window.sessionStorage.getItem('userid');
this.cartService.getCartsum(this.uid).subscribe(res=>{
this.grandTotal1=res;
})
}
removeItem(cid:number)
{
this.cartService.deleteCartItem(cid).subscribe(data => {
this.cartdto.forEach((i, index) => {
if (i.cid == cid) {
this.cartdto.splice(index, 1);
this.cartService.getCartsum(this.uid).subscribe(res=>{
this.grandTotal1=res;
})
}
})
}, (err: any) => {
console.log(err);
})
this.cartService.deleteOrderItem(cid).subscribe(data => {
this.cartdto.forEach((i, index) => {
if (i.cid == cid) {
this.cartdto.splice(index, 1);
}
})
}, (err: any) => {
console.log(err);
})
}
inc(prod:any,ccid:number){
prod.quantity = prod.quantity + 1;
this.qty = prod.quantity
this.cid=ccid;
console.log(this.qty,this.cid);
this.cartService.addquantity(this.cid,this.qty).subscribe(data=>{
this.qty1=data;
console.log(this.qty1);
this.uid = window.sessionStorage.getItem('userid');
this.cartService.getCartsum(this.uid).subscribe(res=>{
this.grandTotal1=res;
})
})
}
dec(prod:any,ccid:number){
if(prod.quantity != 1)
{
prod.quantity = prod.quantity - 1;
this.qty = prod.quantity
this.cid=ccid;
console.log(this.qty,this.cid);
this.cartService.addquantity(this.cid,this.qty).subscribe(data=>{
this.qty1=data;
console.log(this.qty1);
this.uid = window.sessionStorage.getItem('userid');
this.cartService.getCartsum(this.uid).subscribe(res=>{
this.grandTotal1=res;
})
})
}
}
addquantity(id:number,quantity:number)
{
this.qty = quantity
this.cid=id;
console.log(this.qty,this.cid);
this.cartService.addquantity(this.cid,this.qty).subscribe(data=>{
this.qty=data;
console.log(this.qty);
})
}
getMultiply(price:number, quantity:number)
{
return price * quantity;
}
}

0
FrontEnd/src/app/components/category/category.component.css

1
FrontEnd/src/app/components/category/category.component.html

@ -0,0 +1 @@
<p>category works!</p>

25
FrontEnd/src/app/components/category/category.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { CategoryComponent } from './category.component';
describe('CategoryComponent', () => {
let component: CategoryComponent;
let fixture: ComponentFixture<CategoryComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ CategoryComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(CategoryComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

15
FrontEnd/src/app/components/category/category.component.ts

@ -0,0 +1,15 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-category',
templateUrl: './category.component.html',
styleUrls: ['./category.component.css']
})
export class CategoryComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
}

0
FrontEnd/src/app/components/dairy/dairy.component.css

170
FrontEnd/src/app/components/dairy/dairy.component.html

@ -0,0 +1,170 @@
<style>
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
width: 250px;
margin: auto;
text-align: center;
font-family: arial;
}
.price {
color: grey;
font-size: 22px;
}
.card button {
border: none;
outline: 0;
padding: 12px;
color: white;
background-color: #000;
text-align: center;
cursor: pointer;
width: 100%;
font-size: 18px;
}
.card button:hover {
opacity: 0.7;
}
*{
box-sizing: border-box;
}
body {
font-family: Arial, Helvetica, sans-serif;
}
/* Float four columns side by side */
.column {
float: left;
width: 25%;
padding: 0 10px;
}
/* Remove extra left and right margins, due to padding in columns */
.row {margin: 0 -5px;}
/* Clear floats after the columns */
.row:after {
content: "";
display: table;
clear: both;
}
/* Style the counter cards */
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2); /* this adds the "card" effect */
padding: 16px;
text-align: center;
background-color: #f1f1f1;
}
/* Responsive columns - one column layout (vertical) on small screens */
@media screen and (max-width: 600px) {
.column {
width: 100%;
display: block;
margin-bottom: 20px;
}
}
.grid-container {
display: grid;
grid-template-columns: auto auto auto;
width: 100%;
}
.grid-item{
display: table-cell;
padding: 15px;
}
.topnav {
background-color: #333;
overflow: hidden;
}
/* Style the links inside the navigation bar */
.topnav a {
float: center;
color: #f2f2f2;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
/* Change the color of links on hover */
.topnav a:hover {
background-color: #ddd;
color: black;
}
/* Add a color to the active/current link */
.topnav a.active {
background-color: #04AA6D;
color: white;
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</style>
<!DOCTYPE html>
<html lang="en">
<body>
<div class="banner">
<div class="menu1" >
<ul>
<li><a href="products/fruits">FRUITS</a></li>
<li><a href="products/household">HOUSEHOLD</a></li>
<li><a href="products/dairy">DAIRY</a></li>
<li><a href="products/wholegrain">WHOLEGRAIN</a></li>
<li><a href="products/snacks">SNACKS</a></li>
</ul>
</div>
<div class="grid-container" >
<div class="grid-item"*ngFor="let i of products">
<div class="card">
<img src={{i.image}} style="width:80%">
<h2 style="color:black">{{ i.name }}</h2>
<p class="price">Rs. {{ i.price }}</p>
<p><button>Add to Cart</button></p>
</div>
</div>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</div>
</body>
</html>

25
FrontEnd/src/app/components/dairy/dairy.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { DairyComponent } from './dairy.component';
describe('DairyComponent', () => {
let component: DairyComponent;
let fixture: ComponentFixture<DairyComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ DairyComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(DairyComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

27
FrontEnd/src/app/components/dairy/dairy.component.ts

@ -0,0 +1,27 @@
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import { Products } from 'src/app/model/Products';
import { ProductsService } from 'src/app/service/products.service';
@Component({
selector: 'app-dairy',
templateUrl: './dairy.component.html',
styleUrls: ['./dairy.component.css']
})
export class DairyComponent implements OnInit {
products:Products[];
name:string;
constructor(private productsService:ProductsService, private route:Router) {
this.products=[];
this.name='Dairy';
}
ngOnInit(): void {
this.productsService.getProductsByCategory(this.name).subscribe(data=>{
this.products=data;
})
}
}

0
FrontEnd/src/app/components/fruits/fruits.component.css

171
FrontEnd/src/app/components/fruits/fruits.component.html

@ -0,0 +1,171 @@
<style>
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
width: 250px;
margin: auto;
text-align: center;
font-family: arial;
}
.price {
color: grey;
font-size: 22px;
}
.card button {
border: none;
outline: 0;
padding: 12px;
color: white;
background-color: #000;
text-align: center;
cursor: pointer;
width: 100%;
font-size: 18px;
}
.card button:hover {
opacity: 0.7;
}
*{
box-sizing: border-box;
}
body {
font-family: Arial, Helvetica, sans-serif;
}
/* Float four columns side by side */
.column {
float: left;
width: 25%;
padding: 0 10px;
}
/* Remove extra left and right margins, due to padding in columns */
.row {margin: 0 -5px;}
/* Clear floats after the columns */
.row:after {
content: "";
display: table;
clear: both;
}
/* Style the counter cards */
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2); /* this adds the "card" effect */
padding: 16px;
text-align: center;
background-color: #f1f1f1;
}
/* Responsive columns - one column layout (vertical) on small screens */
@media screen and (max-width: 600px) {
.column {
width: 100%;
display: block;
margin-bottom: 20px;
}
}
.grid-container {
display: grid;
grid-template-columns: auto auto auto;
width: 100%;
}
.grid-item{
display: table-cell;
padding: 15px;
}
.topnav {
background-color: #333;
overflow: hidden;
}
/* Style the links inside the navigation bar */
.topnav a {
float: center;
color: #f2f2f2;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
/* Change the color of links on hover */
.topnav a:hover {
background-color: #ddd;
color: black;
}
/* Add a color to the active/current link */
.topnav a.active {
background-color: #04AA6D;
color: white;
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</style>
<!DOCTYPE html>
<html lang="en">
<body>
<div class="banner">
<div class="menu1" >
<ul>
<li><a href="products/fruits">FRUITS</a></li>
<li><a href="products/household">HOUSEHOLD</a></li>
<li><a href="products/dairy">DAIRY</a></li>
<li><a href="products/wholegrain">WHOLEGRAIN</a></li>
<li><a href="products/snacks">SNACKS</a></li>
</ul>
</div>
<div class="grid-container" >
<div class="grid-item"*ngFor="let i of products">
<div class="card">
<img src={{i.image}} style="width:80%">
<h2 style="color:black">{{ i.name }}</h2>
<p class="price">Rs. {{ i.price }}</p>
<p><button>Add to Cart</button></p>
</div>
</div>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</div>
</body>
</html>

25
FrontEnd/src/app/components/fruits/fruits.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { FruitsComponent } from './fruits.component';
describe('FruitsComponent', () => {
let component: FruitsComponent;
let fixture: ComponentFixture<FruitsComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ FruitsComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(FruitsComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

27
FrontEnd/src/app/components/fruits/fruits.component.ts

@ -0,0 +1,27 @@
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import { Products } from 'src/app/model/Products';
import { ProductsService } from 'src/app/service/products.service';
@Component({
selector: 'app-fruits',
templateUrl: './fruits.component.html',
styleUrls: ['./fruits.component.css']
})
export class FruitsComponent implements OnInit {
products:Products[];
name:string;
constructor(private productsService:ProductsService, private route:Router) {
this.products=[];
this.name='Fruits & Veggies';
}
ngOnInit(): void {
this.productsService.getProductsByCategory(this.name).subscribe(data=>{
this.products=data;
})
}
}

0
FrontEnd/src/app/components/household/household.component.css

170
FrontEnd/src/app/components/household/household.component.html

@ -0,0 +1,170 @@
<style>
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
width: 250px;
margin: auto;
text-align: center;
font-family: arial;
}
.price {
color: grey;
font-size: 22px;
}
.card button {
border: none;
outline: 0;
padding: 12px;
color: white;
background-color: #000;
text-align: center;
cursor: pointer;
width: 100%;
font-size: 18px;
}
.card button:hover {
opacity: 0.7;
}
*{
box-sizing: border-box;
}
body {
font-family: Arial, Helvetica, sans-serif;
}
/* Float four columns side by side */
.column {
float: left;
width: 25%;
padding: 0 10px;
}
/* Remove extra left and right margins, due to padding in columns */
.row {margin: 0 -5px;}
/* Clear floats after the columns */
.row:after {
content: "";
display: table;
clear: both;
}
/* Style the counter cards */
.card {
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2); /* this adds the "card" effect */
padding: 16px;
text-align: center;
background-color: #f1f1f1;
}
/* Responsive columns - one column layout (vertical) on small screens */
@media screen and (max-width: 600px) {
.column {
width: 100%;
display: block;
margin-bottom: 20px;
}
}
.grid-container {
display: grid;
grid-template-columns: auto auto auto;
width: 100%;
}
.grid-item{
display: table-cell;
padding: 15px;
}
.topnav {
background-color: #333;
overflow: hidden;
}
/* Style the links inside the navigation bar */
.topnav a {
float: center;
color: #f2f2f2;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
/* Change the color of links on hover */
.topnav a:hover {
background-color: #ddd;
color: black;
}
/* Add a color to the active/current link */
.topnav a.active {
background-color: #04AA6D;
color: white;
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
</style>
<!DOCTYPE html>
<html lang="en">
<body>
<div class="banner">
<div class="menu1" >
<ul>
<li><a href="products/fruits">FRUITS</a></li>
<li><a href="products/household">HOUSEHOLD</a></li>
<li><a href="products/dairy">DAIRY</a></li>
<li><a href="products/wholegrain">WHOLEGRAIN</a></li>
<li><a href="products/snacks">SNACKS</a></li>
</ul>
</div>
<div class="grid-container" >
<div class="grid-item"*ngFor="let i of products">
<div class="card">
<img src={{i.image}} style="width:80%">
<h2 style="color:black">{{ i.name }}</h2>
<p class="price">Rs. {{ i.price }}</p>
<p><button>Add to Cart</button></p>
</div>
</div>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</div>
</body>
</html>

25
FrontEnd/src/app/components/household/household.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { HouseholdComponent } from './household.component';
describe('HouseholdComponent', () => {
let component: HouseholdComponent;
let fixture: ComponentFixture<HouseholdComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ HouseholdComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(HouseholdComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

26
FrontEnd/src/app/components/household/household.component.ts

@ -0,0 +1,26 @@
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import { Products } from 'src/app/model/Products';
import { ProductsService } from 'src/app/service/products.service';
@Component({
selector: 'app-household',
templateUrl: './household.component.html',
styleUrls: ['./household.component.css']
})
export class HouseholdComponent implements OnInit {
products:Products[];
name:string;
constructor(private productsService:ProductsService, private route:Router) {
this.products=[];
this.name='Household';
}
ngOnInit(): void {
this.productsService.getProductsByCategory(this.name).subscribe(data=>{
this.products=data;
})
}
}

0
FrontEnd/src/app/components/order/order.component.css

273
FrontEnd/src/app/components/order/order.component.html

@ -0,0 +1,273 @@
<style>
*{
box-sizing: border-box;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
}
body{
font-family: Helvetica;
-webkit-font-smoothing: antialiased;
background: rgba( 71, 147, 227, 1);
}
h2{
text-align: center;
font-size: 18px;
text-transform: uppercase;
letter-spacing: 1px;
color: white;
padding: 30px 0;
}
/* Table Styles */
.table-wrapper{
margin: 20px 200px 70px;
box-shadow: 0px 35px 50px rgba( 0, 0, 0, 0.2 );
}
.fl-table {
border-radius: 5px;
font-size: 16px;
font-weight: normal;
border: none;
border-collapse: collapse;
width: 100%;
max-width: 100%;
white-space: nowrap;
background-color: white;
}
.fl-table td, .fl-table th {
text-align: center;
padding: 8px;
}
.fl-table td {
border-right: 1px solid #f8f8f8;
font-size: 12px;
}
.fl-table thead th {
color: #ffffff;
background: #4FC3A1;
}
.fl-table thead th:nth-child(odd) {
color: #ffffff;
background: #324960;
}
.fl-table tr:nth-child(even) {
background: #F8F8F8;
}
/* Responsive */
@media (max-width: 767px) {
.fl-table {
display: block;
width: 100%;
}
.table-wrapper:before{
content: "Scroll horizontally >";
display: block;
text-align: right;
font-size: 11px;
color: white;
padding: 0 0 10px;
}
.fl-table thead, .fl-table tbody, .fl-table thead th {
display: block;
}
.fl-table thead th:last-child{
border-bottom: none;
}
.fl-table thead {
float: left;
}
.fl-table tbody {
position: relative;
overflow-x: auto;
}
.fl-table td, .fl-table th {
padding: 20px .625em .625em .625em;
height: 60px;
vertical-align: middle;
box-sizing: border-box;
overflow-x: hidden;
overflow-y: auto;
width: 120px;
font-size: 16px;
text-overflow: ellipsis;
}
.fl-table thead th {
text-align: left;
border-bottom: 1px solid #f7f7f9;
}
.fl-table tbody tr {
display: table-cell;
}
.fl-table tbody tr:nth-child(odd) {
background: none;
}
.fl-table tr:nth-child(even) {
background: transparent;
}
.fl-table tr td:nth-child(odd) {
background: #F8F8F8;
border-right: 1px solid #E6E4E4;
}
.fl-table tr td:nth-child(even) {
border-right: 1px solid #E6E4E4;
}
.fl-table tbody td {
display: block;
text-align: center;
}
}
.banner {
/* The image used */
background-image:
url(1.jpg);
background-position: center;
background-size: cover;
}
.banner1 {
/* The image used */
background-image:
url(9.png);
background-position: center;
background-size: cover;
}
.quantity {
display: flex;
justify-content: center;
}
.quantity button {
width: 35px;
height: 35px;
border: 1px solid #000;
color: #000;
border-radius: 0;
background: #fff
}
.quantity input {
border: none;
border-top: 1px solid #000;
border-bottom: 1px solid #000;
text-align: center;
width: 100px;
font-size: 20px;
color: #000;
font-weight: 300;
}
.total-price {
text-align: center;
font-size: 30px;
color: black;
}
.total-price .fa-rupee {
display: inline-block;
font-size: 90%;
margin-right: 5px;
}
@import url('https://fonts.googleapis.com/css?family=Lato:400,700,900|Open+Sans:300,400|Oswald:400,700');
* {
padding: 0;
margin: 0;
box-sizing: border-box;
font-family: 'Lato', sans-serif;
font-weight: normal;
}
.item {
display: flex;
align-items: center;
flex-wrap: wrap;
}
.btn-pay {
background-color: #C800Da;
border: 0;
color: #fff;
font-weight: 600;
}
.fa-ticket {
color: #0e1fa1;
}
h1 {
text-align: center;
}
</style>
<div class="banner">
<br><br><br><br><br><br><br>
<ng-container *ngIf="orderdto.length!=0">
<h1>Congratulations your Order is Placed!</h1>
<div class="table-wrapper">
<table class="fl-table">
<tr *ngFor="let i of orderdto; let in=index">
<th>ORDER NO : {{i.orderNumber}}</th>
<th></th>
<th><img src="{{i.image}}" style="width:80px"><br>{{i.pname}} @ ₹ {{i.price}}<br></th>
<th>X</th>
<th>{{i.quantity}} QTY</th>
<th>₹ {{i.totalPrice}}</th>
<th></th>
</tr>
<tr>
<th></th>
</tr>
<tr>
<th></th>
<th>{{orderdto.length}} ITEMS</th>
<th></th>
<th></th>
<th></th>
<th><strong text-align="right">PAYABLE AMOUNT : ₹ {{grandTotal}} <br><br> MODE : CASH ON DELIVERY <br><br>STATUS : DELIVERY BY TOMORROW</strong></th>
<th></th>
</tr>
<tr>
<th></th>
</tr>
</table>
</div>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</ng-container>
<ng-container *ngIf="orderdto.length==0">
<div class="banner1">
<br>&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<img src="https://i.pinimg.com/originals/ff/3d/66/ff3d66d438ddff2c520db4d26fce8760.jpg" style="width:40%">
</div>
<br><br><br><br><br><br><br><br><br>
</ng-container>
</div>

25
FrontEnd/src/app/components/order/order.component.spec.ts

@ -0,0 +1,25 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { OrderComponent } from './order.component';
describe('OrderComponent', () => {
let component: OrderComponent;
let fixture: ComponentFixture<OrderComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ OrderComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(OrderComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

Some files were not shown because too many files changed in this diff

Loading…
Cancel
Save