Compare commits
merge into: pranathi_hexa:master
pranathi_hexa:dailycart_cm
pranathi_hexa:dailycart_dd
pranathi_hexa:dailycart_po
pranathi_hexa:master
pull from: pranathi_hexa:dailycart_dd
pranathi_hexa:dailycart_cm
pranathi_hexa:dailycart_dd
pranathi_hexa:dailycart_po
pranathi_hexa:master
2 Commits
master
...
dailycart_
| Author | SHA1 | Message | Date |
|---|---|---|---|
|
|
55420679b1 |
add
|
4 years ago |
|
|
71187f1ada |
add
|
4 years ago |
143 changed files with 19468 additions and 0 deletions
Split View
Diff Options
-
33BackEnd/DailyCart_DD/.gitignore
-
117BackEnd/DailyCart_DD/.mvn/wrapper/MavenWrapperDownloader.java
-
BINBackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.jar
-
2BackEnd/DailyCart_DD/.mvn/wrapper/maven-wrapper.properties
-
310BackEnd/DailyCart_DD/mvnw
-
182BackEnd/DailyCart_DD/mvnw.cmd
-
95BackEnd/DailyCart_DD/pom.xml
-
14BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/CorsConfig.java
-
13BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/DailyCartDdApplication.java
-
57BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/SecurityConfig.java
-
44BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/config/MessagingConfig.java
-
127BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CartController.java
-
46BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/CategoryController.java
-
117BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/OrderController.java
-
70BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/ProductController.java
-
65BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/controller/UserController.java
-
86BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Cartdto.java
-
87BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/dto/Orderdto.java
-
77BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Cart.java
-
37BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Category.java
-
183BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Order.java
-
59BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/OrderStatus.java
-
81BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/Product.java
-
117BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/model/User.java
-
32BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/publisher/OrderPublisher.java
-
26BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CartRepository.java
-
9BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/CategoryRepository.java
-
19BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/OrderRepository.java
-
15BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/ProductRepository.java
-
20BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/repository/UserRepository.java
-
23BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/CartService.java
-
27BackEnd/DailyCart_DD/src/main/java/com/myrestapp/demo/service/MyUserDetailsService.java
-
16BackEnd/DailyCart_DD/src/main/resources/application.properties
-
19BackEnd/DailyCart_DD/src/test/java/com/myrestapp/demo/DailyCartDdApplicationTests.java
-
17FrontEnd/.browserslistrc
-
16FrontEnd/.editorconfig
-
45FrontEnd/.gitignore
-
27FrontEnd/README.md
-
109FrontEnd/angular.json
-
44FrontEnd/karma.conf.js
-
12104FrontEnd/package-lock.json
-
40FrontEnd/package.json
-
6FrontEnd/proxy.config.json
-
BINFrontEnd/src/1.jpg
-
754FrontEnd/src/10.htm
-
BINFrontEnd/src/11.png
-
BINFrontEnd/src/2.jpg
-
BINFrontEnd/src/3.jpg
-
BINFrontEnd/src/4.png
-
BINFrontEnd/src/5.png
-
BINFrontEnd/src/6.png
-
BINFrontEnd/src/7.jpg
-
BINFrontEnd/src/8.png
-
BINFrontEnd/src/9.png
-
38FrontEnd/src/app/app-routing.module.ts
-
0FrontEnd/src/app/app.component.css
-
32FrontEnd/src/app/app.component.html
-
35FrontEnd/src/app/app.component.spec.ts
-
30FrontEnd/src/app/app.component.ts
-
52FrontEnd/src/app/app.module.ts
-
0FrontEnd/src/app/auth/login/login.component.css
-
108FrontEnd/src/app/auth/login/login.component.html
-
25FrontEnd/src/app/auth/login/login.component.spec.ts
-
53FrontEnd/src/app/auth/login/login.component.ts
-
16FrontEnd/src/app/auth/service/auth-guard.service.spec.ts
-
21FrontEnd/src/app/auth/service/auth-guard.service.ts
-
16FrontEnd/src/app/auth/service/auth.service.spec.ts
-
22FrontEnd/src/app/auth/service/auth.service.ts
-
41FrontEnd/src/app/auth/service/user.service.ts
-
0FrontEnd/src/app/auth/signup/signup.component.css
-
125FrontEnd/src/app/auth/signup/signup.component.html
-
25FrontEnd/src/app/auth/signup/signup.component.spec.ts
-
45FrontEnd/src/app/auth/signup/signup.component.ts
-
0FrontEnd/src/app/components/banner/banner.component.css
-
19FrontEnd/src/app/components/banner/banner.component.html
-
25FrontEnd/src/app/components/banner/banner.component.spec.ts
-
29FrontEnd/src/app/components/banner/banner.component.ts
-
16FrontEnd/src/app/components/cart/cart.component.css
-
278FrontEnd/src/app/components/cart/cart.component.html
-
25FrontEnd/src/app/components/cart/cart.component.spec.ts
-
139FrontEnd/src/app/components/cart/cart.component.ts
-
0FrontEnd/src/app/components/category/category.component.css
-
1FrontEnd/src/app/components/category/category.component.html
-
25FrontEnd/src/app/components/category/category.component.spec.ts
-
15FrontEnd/src/app/components/category/category.component.ts
-
0FrontEnd/src/app/components/dairy/dairy.component.css
-
170FrontEnd/src/app/components/dairy/dairy.component.html
-
25FrontEnd/src/app/components/dairy/dairy.component.spec.ts
-
27FrontEnd/src/app/components/dairy/dairy.component.ts
-
0FrontEnd/src/app/components/fruits/fruits.component.css
-
171FrontEnd/src/app/components/fruits/fruits.component.html
-
25FrontEnd/src/app/components/fruits/fruits.component.spec.ts
-
27FrontEnd/src/app/components/fruits/fruits.component.ts
-
0FrontEnd/src/app/components/household/household.component.css
-
170FrontEnd/src/app/components/household/household.component.html
-
25FrontEnd/src/app/components/household/household.component.spec.ts
-
26FrontEnd/src/app/components/household/household.component.ts
-
0FrontEnd/src/app/components/order/order.component.css
-
273FrontEnd/src/app/components/order/order.component.html
-
25FrontEnd/src/app/components/order/order.component.spec.ts
@ -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/ |
|||
@ -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(); |
|||
} |
|||
|
|||
} |
|||
@ -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 |
|||
@ -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 "$@" |
|||
@ -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% |
|||
@ -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> |
|||
@ -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("/**"); |
|||
} |
|||
} |
|||
@ -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); |
|||
} |
|||
|
|||
} |
|||
@ -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(); |
|||
} |
|||
} |
|||
@ -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; |
|||
}*/ |
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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); |
|||
} |
|||
} |
|||
|
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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); |
|||
} |
|||
|
|||
} |
|||
@ -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); |
|||
} |
|||
} |
|||
@ -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; |
|||
} |
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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 + "]"; |
|||
} |
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
|
|||
|
|||
} |
|||
@ -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 !!"; |
|||
}*/ |
|||
} |
|||
@ -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); |
|||
|
|||
|
|||
} |
|||
@ -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>{ |
|||
|
|||
} |
|||
@ -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); |
|||
|
|||
|
|||
|
|||
} |
|||
@ -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); |
|||
|
|||
} |
|||
@ -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); |
|||
|
|||
|
|||
} |
|||
@ -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; |
|||
|
|||
|
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
|
|||
} |
|||
@ -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 |
|||
@ -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() { |
|||
} |
|||
|
|||
|
|||
|
|||
} |
|||
@ -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. |
|||
@ -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 |
|||
@ -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 |
|||
@ -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. |
|||
@ -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" |
|||
} |
|||
@ -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
File diff suppressed because it is too large
View File
@ -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" |
|||
} |
|||
} |
|||
@ -0,0 +1,6 @@ |
|||
{ |
|||
"/api1/*" :{ |
|||
"target" : "http://localhost:1005", |
|||
"secure" : false |
|||
} |
|||
} |
|||
754
FrontEnd/src/10.htm
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -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,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> |
|||
@ -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!'); |
|||
}); |
|||
}); |
|||
@ -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); |
|||
} |
|||
} |
|||
@ -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,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> |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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"); |
|||
}; |
|||
|
|||
} |
|||
|
|||
} |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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; |
|||
|
|||
} |
|||
} |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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; |
|||
} |
|||
} |
|||
@ -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,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> |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,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> |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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) |
|||
}); |
|||
} |
|||
|
|||
} |
|||
@ -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; |
|||
} |
|||
@ -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> |
|||
|
|||
|
|||
|
|||
|
|||
<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> |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,0 +1 @@ |
|||
<p>category works!</p> |
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,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> |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,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> |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,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> |
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
|
|||
@ -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(); |
|||
}); |
|||
}); |
|||
@ -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,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> |
|||
|
|||
|
|||
|
|||
|
|||
<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> |
|||
@ -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
Write
Preview
Loading…
Cancel
Save
Reference in new issue