diff --git a/.classpath b/.classpath index 8041ee8..4c6d0b4 100644 --- a/.classpath +++ b/.classpath @@ -17,15 +17,15 @@ - + - - + + diff --git a/.project b/.project index 4d3d0ff..b459db5 100644 --- a/.project +++ b/.project @@ -47,8 +47,8 @@ - com.genuitec.eclipse.springframework.springnature org.eclipse.m2e.core.maven2Nature + com.genuitec.eclipse.springframework.springnature org.eclipse.wst.common.project.facet.core.nature org.eclipse.jdt.core.javanature org.eclipse.wst.common.modulecore.ModuleCoreNature diff --git a/.settings/com.genuitec.eclipse.core.prefs b/.settings/com.genuitec.eclipse.core.prefs new file mode 100644 index 0000000..cf29e83 --- /dev/null +++ b/.settings/com.genuitec.eclipse.core.prefs @@ -0,0 +1,3 @@ +eclipse.preferences.version=1 +validator.Checked=src/main/webapp/WEB-INF/view/admin/pageSplit.jsp +validator.Unchecked= diff --git a/.springBeans b/.springBeans new file mode 100644 index 0000000..095bc93 --- /dev/null +++ b/.springBeans @@ -0,0 +1,15 @@ + + + 1 + + + + + + + src/main/resources/spring/spring.xml + src/main/resources/spring/spring-mvc.xml + + + + diff --git a/README.md b/README.md index 3fd52aa..1730db6 100644 --- a/README.md +++ b/README.md @@ -1,82 +1,3 @@ # 简介 -这是个简单的教务系统网站,并且结合了图书订购功能,希望这个小DEMO能对大家学习有帮助 - -# 使用技术 - -IoC容器:spring - -web框架:springmvc - -orm框架:mybatis - -安全框架:shiro - -数据源:dbcp2 - -日志: sl4j - -Json: Gson - -前端框架:Bootstrap - -# 修改 - -# 起步: - -1.初始化项目 - -1)下载Mysql,创建一个数据库名字为giit,导入create.sql与populate.sql,直接运行其中sql即可 - -2)下载Tomcat - -3)使用Intellij Idea导入项目,之后配置项目启动方式,使用刚才下载好的Tomcat - -4)运行 - -![image](https://pic4.zhimg.com/v2-87231f2eb533cdab3d3e04c7a89457af_b.png) - -# 使用简介: - -1.权限介绍: - -根据导入的populate.sql,运行网站初始时会存在四个权限角色: - -1).管理员,账号为admin - -2).学生,账号为student - -3).教师,账号为teache - -4).供应商,账号为supplier - -*密码均为123456* - -# 功能介绍: -## 1.基本信息功能: -其中可以设置一些基本的学校信息,也就是数据库中的实体-关系,之后就可以基于这些基本的关系信息进行更加复杂的功能,例如选课后可以记录多少学生选择了这门课程,只会教师提交图书后计算图书总数可以通过其中的关系得到 - -1)系部信息 - -2)专业信息 - -3)班级信息 - -4)课程信息 - -5)学生管理 - -![image](https://pic1.zhimg.com/v2-44688d7a989ae25d9db6767a50a208f8_b.png) - - -## 2.图书管理功能: -1)教师上传图书 - -2)秘书审批图书 - -3)查看已审核图书 - -![image](https://pic3.zhimg.com/v2-3ff2f0da17e8609f85da3b61671cf0de_b.png) - -# 数据库表结构: -![image](http://7xi78h.com1.z0.glb.clouddn.com/db.png) +无 diff --git a/pom.xml b/pom.xml index 49e749a..12b298a 100644 --- a/pom.xml +++ b/pom.xml @@ -11,11 +11,18 @@ http://maven.apache.org - 4.3.7.RELEASE + 4.1.5.RELEASE 1.4.0-RC2 + 3.15 + 2.8.7 + 5.22.0 + + Activiti + https://maven.alfresco.com/nexus/content/groups/public/ + maven-net-cn Maven China Mirror @@ -41,6 +48,60 @@ hamcrest-core 1.3 + + + + + + + org.apache.poi + poi + ${poi.version} + + + org.apache.poi + poi-excelant + ${poi.version} + + + org.apache.poi + poi-ooxml + ${poi.version} + + + org.apache.poi + poi-ooxml-schemas + ${poi.version} + + + org.apache.poi + poi-scratchpad + ${poi.version} + @@ -102,6 +163,16 @@ + + org.springframework + spring-context + ${spring.version} + + + org.springframework + spring-orm + ${spring.version} + org.springframework spring-context-support @@ -175,16 +246,22 @@ jcl-over-slf4j 1.7.12 + + + com.github.pagehelper + pagehelper + 4.1.6 + + + com.github.jsqlparser + jsqlparser + 0.9.6 + - - org.bgee.log4jdbc-log4j2 - log4jdbc-log4j2-jdbc4.1 - 1.16 - org.slf4j slf4j-api @@ -195,11 +272,6 @@ log4j 1.2.17 - - org.apache.logging.log4j - log4j-core - 2.3 - org.slf4j slf4j-log4j12 @@ -233,11 +305,6 @@ - - commons-collections - commons-collections - 3.2.2 - commons-lang commons-lang @@ -255,6 +322,11 @@ gson 2.6 + + com.alibaba + fastjson + 1.2.8 + @@ -263,7 +335,33 @@ 1.3.1 + + + org.apache.commons + commons-lang3 + 3.3.2 + + + com.enterprisedt + edtFTPj + 1.5.3 + + + org.codehaus.mojo + animal-sniffer-annotations + 1.15 + + + com.google.code.findbugs + jsr305 + 3.0.1 + + + com.google.errorprone + error_prone_annotations + 2.0.19 + diff --git a/src/main/java/com/entity/Agent.java b/src/main/java/com/entity/Agent.java new file mode 100644 index 0000000..d7dcca8 --- /dev/null +++ b/src/main/java/com/entity/Agent.java @@ -0,0 +1,116 @@ +package com.entity; + +import java.io.Serializable; +import java.util.List; + +import org.apache.commons.lang.StringUtils; + +import com.entity.enumeration.AgentLevel; +import com.google.common.collect.Lists; + +public class Agent implements Serializable{ + private static final long serialVersionUID = 4678225051291399613L; + private Long id; + private String openid; + private AgentLevel level; + private String agentName; + private List userIds; + private String userIdsStr; + private String area; + + private volatile String usernames; + + public Agent() { + super(); + } + + public Agent(AgentLevel level, String agentName, String area, String openid) { + super(); + this.level = level; + this.agentName = agentName; + this.area = area; + this.openid = openid; + } + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public AgentLevel getLevel() { + return level; + } + + public void setLevel(AgentLevel level) { + this.level = level; + } + + public String getOpenid() { + return openid; + } + + public void setOpenid(String openid) { + this.openid = openid; + } + + public String getAgentName() { + return agentName; + } + + public void setAgentName(String agentName) { + this.agentName = agentName; + } + + public List getUserIds() { + return userIds; + } + + public void setUserIds(List userIds) { + this.userIds = userIds; + StringBuffer buff = new StringBuffer(); + for(String id : userIds) { + buff.append(id).append(','); + } + this.userIdsStr = buff.toString(); + } + + public String getUserIdsStr() { + return userIdsStr; + } + + public void setUserIdsStr(String userIdsStr) { + this.userIdsStr = userIdsStr; + this.userIds = Lists.newArrayList(); + if(!StringUtils.isEmpty(userIdsStr)) { + String[] ids = userIdsStr.split(","); + for(String id : ids) { + this.userIds.add(id); + } + } + } + + public String getArea() { + return area; + } + + public void setArea(String area) { + this.area = area; + } + + public String getUsernames() { + return usernames; + } + + public void setUsernames(String usernames) { + this.usernames = usernames; + } + + @Override + public String toString() { + return "Agent [id=" + id + ", level=" + level + ", agentName=" + + agentName + ", userIds=" + userIds + ", area=" + area + "]"; + } +} diff --git a/src/main/java/com/entity/Area.java b/src/main/java/com/entity/Area.java new file mode 100644 index 0000000..6d46248 --- /dev/null +++ b/src/main/java/com/entity/Area.java @@ -0,0 +1,25 @@ +package com.entity; + +import java.io.Serializable; + +public class Area implements Serializable { + private static final long serialVersionUID = 8852738152430122859L; + private Long id; + private String area; + public Long getId() { + return id; + } + public void setId(Long id) { + this.id = id; + } + public String getArea() { + return area; + } + public void setArea(String area) { + this.area = area; + } + @Override + public String toString() { + return "Area [id=" + id + ", area=" + area + "]"; + } +} diff --git a/src/main/java/com/entity/Car.java b/src/main/java/com/entity/Car.java index 8f9c783..e85a764 100644 --- a/src/main/java/com/entity/Car.java +++ b/src/main/java/com/entity/Car.java @@ -20,6 +20,19 @@ public class Car implements Serializable{ @NotEmpty private Integer weight; + public Car() { + super(); + } + public Car(String carId,Boolean isSale, Integer high, + Integer length, Integer wide, Integer weight) { + super(); + this.isSale = isSale; + this.carId = carId; + this.high = high; + this.length = length; + this.wide = wide; + this.weight = weight; + } public Long getId() { return id; } diff --git a/src/main/java/com/entity/FileInfo.java b/src/main/java/com/entity/FileInfo.java new file mode 100644 index 0000000..ccc03fe --- /dev/null +++ b/src/main/java/com/entity/FileInfo.java @@ -0,0 +1,78 @@ +package com.entity; + +import java.io.Serializable; + +public class FileInfo implements Serializable { + private static final long serialVersionUID = 3517465238526255583L; + private Long id; + private String fileName; + private String filePath; + private String fileType; + private String originalFilename; + private String uuid; + private String uploadTime; + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getFileName() { + return fileName; + } + + public void setFileName(String fileName) { + this.fileName = fileName; + } + + public String getFilePath() { + return filePath; + } + + public void setFilePath(String filePath) { + this.filePath = filePath; + } + + public String getUploadTime() { + return uploadTime; + } + + public void setUploadTime(String uploadTime) { + this.uploadTime = uploadTime; + } + + public String getFileType() { + return fileType; + } + + public void setFileType(String fileType) { + this.fileType = fileType; + } + + public String getOriginalFilename() { + return originalFilename; + } + + public void setOriginalFilename(String originalFilename) { + this.originalFilename = originalFilename; + } + + public String getUuid() { + return uuid; + } + + public void setUuid(String uuid) { + this.uuid = uuid; + } + + @Override + public String toString() { + return "FileInfo [id=" + id + ", fileName=" + fileName + ", filePath=" + + filePath + ", uploadTime=" + uploadTime + ", fileType=" + + fileType + ", originalFilename=" + originalFilename + + ", uuid=" + uuid + "]"; + } +} diff --git a/src/main/java/com/entity/Order.java b/src/main/java/com/entity/Order.java new file mode 100644 index 0000000..7d2c4de --- /dev/null +++ b/src/main/java/com/entity/Order.java @@ -0,0 +1,81 @@ +package com.entity; + +import java.io.Serializable; +import java.util.Date; + +import com.entity.enumeration.OrderType; +import com.entity.enumeration.Status; + +public class Order implements Serializable{ + private static final long serialVersionUID = -2545303099330416597L; + private Long id; + private String openid; + private String carId; + private Integer carCnt; + private Double price; + private Status status; + private OrderType orderType; + private Date startTime; + private Date deliverTime; + public Long getId() { + return id; + } + public void setId(Long id) { + this.id = id; + } + public String getOpenid() { + return openid; + } + public void setOpenid(String openid) { + this.openid = openid; + } + public String getCarId() { + return carId; + } + public void setCarId(String carId) { + this.carId = carId; + } + public Integer getCarCnt() { + return carCnt; + } + public void setCarCnt(Integer carCnt) { + this.carCnt = carCnt; + } + public Double getPrice() { + return price; + } + public void setPrice(Double price) { + this.price = price; + } + public Status getStatus() { + return status; + } + public void setStatus(Status status) { + this.status = status; + } + public OrderType getOrderType() { + return orderType; + } + public void setOrderType(OrderType orderType) { + this.orderType = orderType; + } + public Date getStartTime() { + return startTime; + } + public void setStartTime(Date startTime) { + this.startTime = startTime; + } + public Date getDeliverTime() { + return deliverTime; + } + public void setDeliverTime(Date deliverTime) { + this.deliverTime = deliverTime; + } + @Override + public String toString() { + return "Order [id=" + id + ", openid=" + openid + ", carId=" + carId + + ", carCnt=" + carCnt + ", price=" + price + ", status=" + + status + ", orderType=" + orderType + ", startTime=" + + startTime + ", deliverTime=" + deliverTime + "]"; + } +} diff --git a/src/main/java/com/entity/Procurement.java b/src/main/java/com/entity/Procurement.java new file mode 100644 index 0000000..20e46f6 --- /dev/null +++ b/src/main/java/com/entity/Procurement.java @@ -0,0 +1,130 @@ +package com.entity; + +import java.io.Serializable; +import java.util.Date; + +import org.hibernate.validator.constraints.NotEmpty; + +public class Procurement implements Serializable{ + private static final long serialVersionUID = 6534271072663770032L; + private Long id; + @NotEmpty + private String procureId; + @NotEmpty + private Integer inventory; + @NotEmpty + private Integer startInventory; + @NotEmpty + private Integer endInventory; + @NotEmpty + private Integer price; + @NotEmpty + private Integer startPrice; + @NotEmpty + private Integer endPrice; + @NotEmpty + private String procureTime; + @NotEmpty + private Date startTime; + @NotEmpty + private Date endTime; + + private String procureFilePath; + private String procureFileName; + + public String getProcureFilePath() { + return procureFilePath; + } + public void setProcureFilePath(String procureFilePath) { + this.procureFilePath = procureFilePath; + } + public String getProcureFileName() { + return procureFileName; + } + public void setProcureFileName(String procureFileName) { + this.procureFileName = procureFileName; + } + public Procurement() { + super(); + } + public Procurement(String carId,Boolean isSale, Integer high, + Integer length, Integer wide, Integer weight) { + super(); + this.procureId = procureId; + this.inventory = inventory; + this.price = price; + this.procureTime = procureTime; + } + public Integer getStartInventory() { + return startInventory; + } + public void setStartInventory(Integer startInventory) { + this.startInventory = startInventory; + } + public Integer getEndInventory() { + return endInventory; + } + public void setEndInventory(Integer endInventory) { + this.endInventory = endInventory; + } + public Integer getStartPrice() { + return startPrice; + } + public void setStartPrice(Integer startPrice) { + this.startPrice = startPrice; + } + public Integer getEndPrice() { + return endPrice; + } + public void setEndPrice(Integer endPrice) { + this.endPrice = endPrice; + } + + public Date getStartTime() { + return startTime; + } + public void setStartTime(Date startTime) { + this.startTime = startTime; + } + public Date getEndTime() { + return endTime; + } + public void setEndTime(Date endTime) { + this.endTime = endTime; + } + public Long getId() { + return id; + } + public void setId(Long id) { + this.id = id; + } + public String getProcureId() { + return procureId; + } + public void setProcureId(String procureId) { + this.procureId = procureId; + } + public Integer getInventory() { + return inventory; + } + public void setInventory(Integer inventory) { + this.inventory = inventory; + } + public Integer getPrice() { + return price; + } + public void setPrice(Integer price) { + this.price = price; + } + public String getProcureTime() { + return procureTime; + } + public void setProcureTime(String procureTime) { + this.procureTime = procureTime; + } + @Override + public String toString() { + return "Procurement [id=" + id + ", procureId=" + procureId + ", inventory=" + inventory + + ", price=" + price + ", procureTime=" + procureTime + "]"; + } +} diff --git a/src/main/java/com/entity/User.java b/src/main/java/com/entity/User.java index 797ef46..4092a5b 100644 --- a/src/main/java/com/entity/User.java +++ b/src/main/java/com/entity/User.java @@ -1,17 +1,13 @@ package com.entity; import java.util.ArrayList; +import java.util.Arrays; import java.util.List; import org.hibernate.validator.constraints.NotBlank; -import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; -/** - * Created by c0de8ug on 16-2-9. - */ public class User { - String username; //用户名 @NotBlank String userId; @@ -20,6 +16,7 @@ public class User { String salt; private List roleIds; //拥有的角色列表 private String roleIdsStr; + private String roleDesc; private Boolean locked = Boolean.FALSE; @@ -55,7 +52,15 @@ public List getRoleIds() { return roleIds; } - public void setRoleIds(List roleIds) { + public String getRoleDesc() { + return roleDesc; + } + + public void setRoleDesc(String roleDesc) { + this.roleDesc = roleDesc; + } + + public void setRoleIds(List roleIds) { this.roleIds = roleIds; StringBuilder s = new StringBuilder(); int i = 0; @@ -82,7 +87,7 @@ public void setSalt(String salt) { } public String getCredentialsSalt() { - return username + salt; + return userId + salt; } public String[] getPasswords() { @@ -111,4 +116,13 @@ public void setRoleIdsStr(String roleIdsStr) { roleIds.add(Long.valueOf(roleIdStr)); } } + + @Override + public String toString() { + return "User [username=" + username + ", userId=" + userId + + ", password=" + password + ", passwords=" + + Arrays.toString(passwords) + ", salt=" + salt + ", roleIds=" + + roleIds + ", roleIdsStr=" + roleIdsStr + ", roleDesc=" + + roleDesc + ", locked=" + locked + "]"; + } } diff --git a/src/main/java/com/entity/Vendor.java b/src/main/java/com/entity/Vendor.java new file mode 100644 index 0000000..521cc54 --- /dev/null +++ b/src/main/java/com/entity/Vendor.java @@ -0,0 +1,77 @@ +package com.entity; + +import java.io.Serializable; + +public class Vendor implements Serializable { + private static final long serialVersionUID = -4471300730875048038L; + private Long id; + private String vendorName; + private String contact; + private String url; + private String address; + private String telephone; + private String phone; + private String email; + private Long attachId; + public Long getId() { + return id; + } + public void setId(Long id) { + this.id = id; + } + public String getVendorName() { + return vendorName; + } + public void setVendorName(String vendorName) { + this.vendorName = vendorName; + } + public String getContact() { + return contact; + } + public void setContact(String contact) { + this.contact = contact; + } + public String getUrl() { + return url; + } + public void setUrl(String url) { + this.url = url; + } + public String getAddress() { + return address; + } + public void setAddress(String address) { + this.address = address; + } + public String getTelephone() { + return telephone; + } + public void setTelephone(String telephone) { + this.telephone = telephone; + } + public String getPhone() { + return phone; + } + public void setPhone(String phone) { + this.phone = phone; + } + public Long getAttachId() { + return attachId; + } + public void setAttachId(Long attachId) { + this.attachId = attachId; + } + public String getEmail() { + return email; + } + public void setEmail(String email) { + this.email = email; + } + @Override + public String toString() { + return "Vendor [id=" + id + ", vendorName=" + vendorName + ", contact=" + + contact + ", url=" + url + ", address=" + address + + ", telephone=" + telephone + ", phone=" + phone + ", email=" + + email + ", attachId=" + attachId + "]"; + } +} diff --git a/src/main/java/com/entity/enumeration/AgentLevel.java b/src/main/java/com/entity/enumeration/AgentLevel.java new file mode 100644 index 0000000..2de0a37 --- /dev/null +++ b/src/main/java/com/entity/enumeration/AgentLevel.java @@ -0,0 +1,42 @@ +package com.entity.enumeration; + +import org.springframework.util.StringUtils; + +public enum AgentLevel { + VIP("VIP",0,Integer.MAX_VALUE),NORMAL("普通",0,2000),NOCARE("不关注",2000,5000); + private String name; + private Integer minPrice; + private Integer maxPrice; + AgentLevel(String name,Integer minPrice,Integer maxPrice) { + this.name = name; + this.minPrice=minPrice; + this.maxPrice=maxPrice; + } + public String getName() { + return name; + } + public void setName(String name) { + this.name = name; + } + public Integer getMinPrice() { + return minPrice; + } + public void setMinPrice(Integer minPrice) { + this.minPrice = minPrice; + } + public Integer getMaxPrice() { + return maxPrice; + } + public void setMaxPrice(Integer maxPrice) { + this.maxPrice = maxPrice; + } + public static AgentLevel parse(String text) { + if(!StringUtils.isEmpty(text)) { + for(AgentLevel entry : AgentLevel.values()) { + if(entry.getName().equals(text)) + return entry; + } + } + return null; + } +} \ No newline at end of file diff --git a/src/main/java/com/entity/enumeration/OrderType.java b/src/main/java/com/entity/enumeration/OrderType.java new file mode 100644 index 0000000..571d74f --- /dev/null +++ b/src/main/java/com/entity/enumeration/OrderType.java @@ -0,0 +1,29 @@ +package com.entity.enumeration; + +import org.springframework.util.StringUtils; + + +public enum OrderType { + DISTRIBUTION("分销订单"),DISTRIBUTION_REJECTED("分销退货订单"),DISTRIBUTION_EXCHANGE("分销换货订单"); + + private String name; + OrderType(String name) { + this.name = name; + } + public String getName() { + return name; + } + public void setName(String name) { + this.name = name; + } + + public static AgentLevel parse(String text) { + if(!StringUtils.isEmpty(text)) { + for(AgentLevel entry : AgentLevel.values()) { + if(entry.getName().equals(text)) + return entry; + } + } + return null; + } +} \ No newline at end of file diff --git a/src/main/java/com/entity/enumeration/Status.java b/src/main/java/com/entity/enumeration/Status.java new file mode 100644 index 0000000..54dfc6d --- /dev/null +++ b/src/main/java/com/entity/enumeration/Status.java @@ -0,0 +1,6 @@ +package com.entity.enumeration; + + +public enum Status { + START,END,UNAUDIT,AUDIT,NON_PAYMENT,PAYMENT,NOT_DISTRIBUTION,DISTRIBUTION; +} \ No newline at end of file diff --git a/src/main/java/com/entity/vo/UserVo.java b/src/main/java/com/entity/vo/UserVo.java deleted file mode 100644 index a6ec348..0000000 --- a/src/main/java/com/entity/vo/UserVo.java +++ /dev/null @@ -1,20 +0,0 @@ -package com.entity.vo; - -import com.entity.User; - -/** - * Created by c0de8ug on 16-2-21. - */ -public class UserVo extends User { - String roleIdsStr; - - @Override - public String getRoleIdsStr() { - return roleIdsStr; - } - - @Override - public void setRoleIdsStr(String roleIdsStr) { - this.roleIdsStr = roleIdsStr; - } -} diff --git a/src/main/java/com/realm/UserRealm.java b/src/main/java/com/realm/UserRealm.java index 27e724f..896e6a0 100644 --- a/src/main/java/com/realm/UserRealm.java +++ b/src/main/java/com/realm/UserRealm.java @@ -37,11 +37,11 @@ public class UserRealm extends AuthorizingRealm { @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) { - String username = (String)principals.getPrimaryPrincipal(); + String userid = (String)principals.getPrimaryPrincipal(); SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo(); - authorizationInfo.setRoles(userBiz.findRoles(username)); - if("admin".equals(username)) { + authorizationInfo.setRoles(userBiz.findRoles(userid)); + if("admin".equals(userid)) { List list = resourceBiz.findAll(); Set set = Sets.newHashSet(); for(Resource r : list) { @@ -49,7 +49,7 @@ protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principal } authorizationInfo.setStringPermissions(set); } else { - authorizationInfo.setStringPermissions(userBiz.findPermissions(username)); + authorizationInfo.setStringPermissions(userBiz.findPermissions(userid)); } return authorizationInfo; } @@ -57,9 +57,9 @@ protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principal @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authcToken) throws AuthenticationException { UsernamePasswordToken token = (UsernamePasswordToken) authcToken; - String username = token.getUsername(); + String userid = token.getUsername(); - User user = userBiz.findByUsername(username); + User user = userBiz.findById(userid); if(user == null) { throw new UnknownAccountException();//没找到帐号 diff --git a/src/main/java/com/system/controller/LoginController.java b/src/main/java/com/system/controller/LoginController.java index cc70b4d..a71e058 100644 --- a/src/main/java/com/system/controller/LoginController.java +++ b/src/main/java/com/system/controller/LoginController.java @@ -43,16 +43,6 @@ public String login(HttpServletRequest req, ModelMap modelMap, HttpSession sessi String principal = (String) subject.getPrincipal(); session.setAttribute("username", principal); return "/admin/main"; - /* switch (principal) { - case "admin": - return "/admin/main"; - case "teacher": - return "/teacher/main"; - case "student": - return "/student/main"; - case "supplier": - return "redirect:supplier.do/supplier.view"; - }*/ } return "forward:login.jsp"; diff --git a/src/main/java/com/system/controller/MainController.java b/src/main/java/com/system/controller/MainController.java index df61971..c461fe8 100644 --- a/src/main/java/com/system/controller/MainController.java +++ b/src/main/java/com/system/controller/MainController.java @@ -3,10 +3,6 @@ import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; -/** - * Created by c0de8ug on 16-2-16. - */ - @Controller @RequestMapping("main.do") public class MainController { @@ -15,14 +11,4 @@ public class MainController { public String adminMainView() { return "/admin/main"; } - - @RequestMapping("student") - public String studentMainView() { - return "/student/main"; - } - - @RequestMapping("teacher") - public String teacherMainView() { - return "/teacher/main"; - } } diff --git a/src/main/java/com/system/controller/ResourceController.java b/src/main/java/com/system/controller/ResourceController.java index 1e23175..765d330 100644 --- a/src/main/java/com/system/controller/ResourceController.java +++ b/src/main/java/com/system/controller/ResourceController.java @@ -1,49 +1,75 @@ package com.system.controller; +import java.util.List; + import org.apache.log4j.Logger; -import org.apache.shiro.authz.annotation.RequiresRoles; +import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.servlet.mvc.support.RedirectAttributes; +import com.entity.Resource; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; import com.system.service.ResourceBiz; -/** - * Created by c0de8ug on 16-2-21. - */ @Controller - @RequestMapping("/resource.do") public class ResourceController { Logger log = Logger.getLogger(ResourceController.class); @Autowired private ResourceBiz resourceBiz; - - @RequiresRoles("admin") + + @RequiresPermissions("resource:query") @RequestMapping("resource.view") public String resourceView(Model model) { - model.addAttribute("resourceList",resourceBiz.findAll()); + return "forward:/resource.do/resource.view/0/10"; + } + + @RequiresPermissions("resource:query") + @RequestMapping("resource.view/{pageNum}/{pageSize}") + public String resourceView(Model model,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List resourceList = resourceBiz.findAll(); + PageInfo page = new PageInfo(resourceList); + model.addAttribute("resourceList",resourceList); + model.addAttribute("page",page); return "/admin/system/resource/resource"; } - @RequiresRoles("admin") + @RequiresPermissions("resource:add") @RequestMapping("resource_add.view") public String resourceAddView(Model model) { - model.addAttribute("resourceList", resourceBiz.findAll()); return "/admin/system/resource/resource_add"; } - - @RequiresRoles("admin") + + @RequiresPermissions("resource:add") @RequestMapping("add") public String add(com.entity.Resource resource, RedirectAttributes redirectAttributes) { resourceBiz.createResource(resource); return "redirect:/resource.do/resource.view"; } + + @RequiresPermissions("resource:update") + @RequestMapping("resource_update.view") + public String resourceUpdateView(Long id,Model model) { + model.addAttribute("resource", resourceBiz.findOne(id)); + return "/admin/system/resource/resource_update"; + } + + @RequiresPermissions("resource:update") + @RequestMapping("update") + public String update(com.entity.Resource resource, RedirectAttributes redirectAttributes) { + resourceBiz.updateResource(resource); + return "redirect:/resource.do/resource.view"; + } - @RequiresRoles("admin") + @RequiresPermissions("resource:delete") @RequestMapping("delete") public String delete(Long id, RedirectAttributes redirectAttributes) { resourceBiz.deleteResource(id); diff --git a/src/main/java/com/system/controller/RoleController.java b/src/main/java/com/system/controller/RoleController.java index a5d1d73..ca162fa 100644 --- a/src/main/java/com/system/controller/RoleController.java +++ b/src/main/java/com/system/controller/RoleController.java @@ -1,13 +1,18 @@ package com.system.controller; -import org.apache.shiro.authz.annotation.RequiresRoles; +import java.util.List; + +import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.servlet.mvc.support.RedirectAttributes; import com.entity.Role; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; import com.system.service.ResourceBiz; import com.system.service.RoleBiz; @@ -25,22 +30,33 @@ public class RoleController { @Autowired private ResourceBiz resourceBiz; - - @RequiresRoles("admin") + + @RequiresPermissions("role:query") @RequestMapping("role.view") public String roleView(Model model) { - model.addAttribute("roleList", roleBiz.findAll()); + return "forward:/role.do/role.view/0/10"; + } + + @RequiresPermissions("role:query") + @RequestMapping("role.view/{pageNum}/{pageSize}") + public String roleView(Model model,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = roleBiz.findAll(); + PageInfo page = new PageInfo(list); + model.addAttribute("roleList",list); + model.addAttribute("page",page); return "/admin/system/role/role"; } - @RequiresRoles("admin") + @RequiresPermissions("role:add") @RequestMapping("role_add.view") public String roleAddView(Model model) { model.addAttribute("resourceList", resourceBiz.findAll()); return "/admin/system/role/role_add"; } - @RequiresRoles("admin") + @RequiresPermissions("role:update") @RequestMapping("role_update.view") public String roleUpdateView(Long id,Model model) { model.addAttribute("role", roleBiz.findOne(id)); @@ -48,67 +64,24 @@ public String roleUpdateView(Long id,Model model) { return "/admin/system/role/role_update"; } - @RequiresRoles("admin") + @RequiresPermissions("role:add") @RequestMapping("add") public String add(Role role, RedirectAttributes redirectAttributes) { roleBiz.createRole(role); return "redirect:/role.do/role.view"; } - @RequiresRoles("admin") + @RequiresPermissions("role:update") @RequestMapping("update") public String update(Role role, RedirectAttributes redirectAttributes) { roleBiz.updateRole(role); return "redirect:/role.do/role.view"; } - @RequiresRoles("admin") + @RequiresPermissions("role:delete") @RequestMapping("delete") public String delete(Long id, RedirectAttributes redirectAttributes) { roleBiz.deleteRole(id); return "redirect:/role.do/role.view"; } - -// -// @RequiresPermissions("role:create") -// @RequestMapping(value = "/create", method = RequestMethod.GET) -// public String showCreateForm(Model model) { -// setCommonData(model); -// model.addAttribute("role", new Role()); -// model.addAttribute("op", "新增"); -// return "role/edit"; -// } -// -// @RequiresPermissions("role:update") -// @RequestMapping(value = "/{id}/update", method = RequestMethod.GET) -// public String showUpdateForm(@PathVariable("id") Long id, Model model) { -// setCommonData(model); -// model.addAttribute("role", roleBiz.findOne(id)); -// model.addAttribute("op", "修改"); -// return "role/edit"; -// } -// -// @RequiresPermissions("role:update") -// @RequestMapping(value = "/{id}/update", method = RequestMethod.POST) -// public String update(Role role, RedirectAttributes redirectAttributes) { -// roleBiz.updateRole(role); -// redirectAttributes.addFlashAttribute("msg", "修改成功"); -// return "redirect:/role"; -// } -// -// @RequiresPermissions("role:delete") -// @RequestMapping(value = "/{id}/delete", method = RequestMethod.GET) -// public String showDeleteForm(@PathVariable("id") Long id, Model model) { -// setCommonData(model); -// model.addAttribute("role", roleBiz.findOne(id)); -// model.addAttribute("op", "删除"); -// return "role/edit"; -// } - - -// private void setCommonData(Model model) { -// model.addAttribute("resourceList", roleBiz.findAll()); -// } - - } diff --git a/src/main/java/com/system/controller/UserController.java b/src/main/java/com/system/controller/UserController.java index 4705d5f..3e70f6e 100644 --- a/src/main/java/com/system/controller/UserController.java +++ b/src/main/java/com/system/controller/UserController.java @@ -1,23 +1,22 @@ package com.system.controller; import java.lang.reflect.InvocationTargetException; +import java.util.List; -import org.apache.shiro.authz.annotation.RequiresRoles; +import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import com.entity.User; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; import com.system.service.RoleBiz; import com.system.service.UserBiz; -/** - * Created by c0de8ug on 16-2-9. - */ - @Controller -@RequiresRoles("admin") @RequestMapping("user.do") public class UserController { @@ -26,22 +25,33 @@ public class UserController { @Autowired private RoleBiz roleBiz; - - @RequiresRoles("admin") + + @RequiresPermissions("user:query") @RequestMapping("user.view") - public String userView(Model m) throws InvocationTargetException, IllegalAccessException { - m.addAttribute("userList", userBiz.findAll()); + public String userView(Model model) { + return "forward:/user.do/user.view/0/10"; + } + + @RequiresPermissions("user:query") + @RequestMapping("user.view/{pageNum}/{pageSize}") + public String userView(Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) throws InvocationTargetException, IllegalAccessException { + PageHelper.startPage(pageNum, pageSize); + List list = userBiz.findAll(); + PageInfo page = new PageInfo(list); + m.addAttribute("userList",list); + m.addAttribute("page",page); return "/admin/system/user/user"; } - @RequiresRoles("admin") + @RequiresPermissions("user:add") @RequestMapping("user_add.view") public String userAddView(Model m) { m.addAttribute("roleList", roleBiz.findAll()); return "/admin/system/user/user_add"; } - @RequiresRoles("admin") + @RequiresPermissions("user:add") @RequestMapping("findById") public String findById(String id, Model m) { m.addAttribute("user", userBiz.findById(id)); @@ -49,14 +59,14 @@ public String findById(String id, Model m) { return "/admin/system/user/user_update"; } - @RequiresRoles("admin") + @RequiresPermissions("user:update") @RequestMapping("update") public String update(User user) { userBiz.update(user); return "redirect:/user.do/user.view"; } - @RequiresRoles("admin") + @RequiresPermissions("user:add") @RequestMapping("add") public String add(User user) { @@ -64,7 +74,7 @@ public String add(User user) { return "redirect:/user.do/user.view"; } - @RequiresRoles("admin") + @RequiresPermissions("user:delete") @RequestMapping("delete") public String delete(String id) { userBiz.delete(id); diff --git a/src/main/java/com/system/dao/ResourceDao.java b/src/main/java/com/system/dao/ResourceDao.java index e223b0f..f1ce376 100644 --- a/src/main/java/com/system/dao/ResourceDao.java +++ b/src/main/java/com/system/dao/ResourceDao.java @@ -5,21 +5,15 @@ import com.entity.Resource; -/** - *

Resource: Zhang Kaitao - *

Date: 14-1-28 - *

Version: 1.0 - */ public interface ResourceDao { public void createResource(Resource resource); - public Resource updateResource(Resource resource); + public void updateResource(Resource resource); public void deleteResource(Long resourceId); Resource findOne(Long resourceId); List findAll(); - } diff --git a/src/main/java/com/system/dao/UserDao.java b/src/main/java/com/system/dao/UserDao.java index c8fbc04..e4e6c96 100644 --- a/src/main/java/com/system/dao/UserDao.java +++ b/src/main/java/com/system/dao/UserDao.java @@ -24,5 +24,5 @@ public interface UserDao { public void updatePassword(@Param("userId") String id, @Param("password") String password); - User findByUsername(String username); + public List findByRole(String role); } diff --git a/src/main/java/com/system/interceptor/BreadcrumbIntercepter.java b/src/main/java/com/system/interceptor/BreadcrumbIntercepter.java index 89189cd..799ccad 100644 --- a/src/main/java/com/system/interceptor/BreadcrumbIntercepter.java +++ b/src/main/java/com/system/interceptor/BreadcrumbIntercepter.java @@ -20,14 +20,11 @@ import com.google.common.collect.Lists; import com.system.model.Breadcrumb; -/** - * Created by c0de8ug on 16-2-14. - */ public class BreadcrumbIntercepter implements HandlerInterceptor { private Logger log = Logger.getLogger(BreadcrumbIntercepter.class); private Properties properties; //private Pattern p1 = Pattern.compile("[//\\a-zA-Z]+?(? breadcrumbs = (List)session.getAttribute("breadcrumbs"); Matcher matcher = pc.matcher(url); @@ -65,7 +62,7 @@ public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletRespo return true; } - if(url.matches("[//\\a-zA-Z]+?(?User: Zhang Kaitao - *

Date: 14-1-28 - *

Version: 1.0 - */ public interface ResourceBiz { public void createResource(Resource resource); - public Resource updateResource(Resource resource); + public void updateResource(Resource resource); public void deleteResource(Long resourceId); Resource findOne(Long resourceId); diff --git a/src/main/java/com/system/service/UserBiz.java b/src/main/java/com/system/service/UserBiz.java index 025d623..a498b52 100644 --- a/src/main/java/com/system/service/UserBiz.java +++ b/src/main/java/com/system/service/UserBiz.java @@ -1,18 +1,17 @@ package com.system.service; -import com.entity.User; -import com.entity.vo.UserVo; - import java.lang.reflect.InvocationTargetException; import java.util.List; import java.util.Set; +import com.entity.User; + /** * Created by c0de8ug on 16-2-9. */ public interface UserBiz { - public List findAll() throws InvocationTargetException, IllegalAccessException; + public List findAll() throws InvocationTargetException, IllegalAccessException; public User findById(String id); @@ -25,9 +24,9 @@ public interface UserBiz { public void changePassword(String userId, String newPassword); - public User findByUsername(String username); - public Set findRoles(String username); public Set findPermissions(String username); + + public List findByRole(String string); } diff --git a/src/main/java/com/system/service/impl/ResourceBizImpl.java b/src/main/java/com/system/service/impl/ResourceBizImpl.java index acba97e..9659a93 100644 --- a/src/main/java/com/system/service/impl/ResourceBizImpl.java +++ b/src/main/java/com/system/service/impl/ResourceBizImpl.java @@ -14,11 +14,6 @@ import com.system.dao.ResourceDao; import com.system.service.ResourceBiz; -/** - *

User: Zhang Kaitao - *

Date: 14-2-14 - *

Version: 1.0 - */ @Service public class ResourceBizImpl implements ResourceBiz { @@ -31,8 +26,8 @@ public void createResource(Resource resource) { } @Override - public Resource updateResource(Resource resource) { - return resourceDao.updateResource(resource); + public void updateResource(Resource resource) { + resourceDao.updateResource(resource); } @Override diff --git a/src/main/java/com/system/service/impl/UserBizImpl.java b/src/main/java/com/system/service/impl/UserBizImpl.java index 7d59d2b..95fb9e6 100644 --- a/src/main/java/com/system/service/impl/UserBizImpl.java +++ b/src/main/java/com/system/service/impl/UserBizImpl.java @@ -1,20 +1,17 @@ package com.system.service.impl; import java.lang.reflect.InvocationTargetException; -import java.util.ArrayList; import java.util.Collections; import java.util.Iterator; import java.util.List; import java.util.Set; -import org.apache.commons.beanutils.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.entity.Role; import com.entity.User; -import com.entity.vo.UserVo; import com.system.dao.RoleDao; import com.system.dao.UserDao; import com.system.service.RoleBiz; @@ -40,11 +37,8 @@ public class UserBizImpl implements UserBiz { private RoleBiz roleBiz; @Override - public List findAll() throws InvocationTargetException, IllegalAccessException { - List userVoList = new ArrayList<>(); + public List findAll() throws InvocationTargetException, IllegalAccessException { List userList = userDao.findAll(); - - Iterator iterator = userList.iterator(); while (iterator.hasNext()) { @@ -52,9 +46,6 @@ public List findAll() throws InvocationTargetException, IllegalAccessExc User user = (User) iterator.next(); List roleIds = user.getRoleIds(); - UserVo userVo = new UserVo(); - BeanUtils.copyProperties(userVo, user); - if (roleIds != null) { int i = 0; int size = roleIds.size(); @@ -66,18 +57,18 @@ public List findAll() throws InvocationTargetException, IllegalAccessExc } Role role = roleDao.findOne(roleIds.get(i)); s.append(role.getDescription()); - userVo.setRoleIdsStr(s.toString()); + user.setRoleDesc(s.toString()); } - - - userVoList.add(userVo); - } - - return userVoList; + return userList; } @Override + public List findByRole(String role) { + return userDao.findByRole(role); + } + + @Override public User findById(String id) { return userDao.findById(id); } @@ -112,13 +103,8 @@ public void changePassword(String userId, String newPassword) { } @Override - public User findByUsername(String username) { - return userDao.findById(username); - } - - @Override - public Set findRoles(String username) { - User user = findByUsername(username); + public Set findRoles(String userid) { + User user = findById(userid); if (user == null) { return Collections.emptySet(); } @@ -126,8 +112,8 @@ public Set findRoles(String username) { } @Override - public Set findPermissions(String username) { - User user = findByUsername(username); + public Set findPermissions(String userid) { + User user = findById(userid); if (user == null) { return Collections.emptySet(); } diff --git a/src/main/java/com/util/Constant.java b/src/main/java/com/util/Constant.java new file mode 100644 index 0000000..6f54626 --- /dev/null +++ b/src/main/java/com/util/Constant.java @@ -0,0 +1,19 @@ +package com.util; + +/** + * 系统常量 + * + * @author wujuan + * + */ +public class Constant { + + public static final String MSG_ERROR = "-1"; + public static final String MSG_CONFLICT = "-2"; + public static final String MSG_OK = "0"; + + public static final String OK_SYS = "成功"; + public static final String ERROR_SYS = "系统错误"; + public static final String ERROR_ANALY = "json解析错误"; + +} diff --git a/src/main/java/com/util/FtpClient.java b/src/main/java/com/util/FtpClient.java new file mode 100644 index 0000000..662273d --- /dev/null +++ b/src/main/java/com/util/FtpClient.java @@ -0,0 +1,86 @@ +package com.util; + +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; + +import com.enterprisedt.net.ftp.FTPClient; +import com.enterprisedt.net.ftp.FTPConnectMode; +import com.enterprisedt.net.ftp.FTPException; +import com.enterprisedt.net.ftp.FTPTransferType; + +public class FtpClient { + private FTPClient ftpClient = null; + + public void connectServer(String server, String user, String password) throws IOException, FTPException { + if (ftpClient == null || !ftpClient.connected()) { + ftpClient = new FTPClient(); + ftpClient.setRemoteHost(server); + ftpClient.setTimeout(500000); + ftpClient.connect(); + ftpClient.login(user, password); + ftpClient.setConnectMode(FTPConnectMode.PASV); + ftpClient.setType(FTPTransferType.BINARY); + } + } + + public void changeDir(String path) { + if (path == null || path.equals("")) { + return; + } + String temp[] = path.split("/"); + for (int i = 0; i < temp.length; i++) { + try { + if (temp[i] == null || temp[i].equals("")) { + continue; + } + ftpClient.chdir(temp[i]); + } catch (FTPException fe) { + try { + ftpClient.mkdir(temp[i]); + ftpClient.chdir(temp[i]); + } catch (Exception e) { + + } + } catch (Exception ee) { + + } + } + } + + public void uploadFile(InputStream in, String filename) { + try { + ftpClient.put(in, filename); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public void uploadFile(byte[] bytes, String filename) { + try { + ftpClient.put(bytes, filename); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public void downLoad(OutputStream out, String filename) { + try { + ftpClient.get(out, filename); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public void close() { + try { + if (ftpClient != null && ftpClient.connected()) { + ftpClient.quit(); + ftpClient = null; + } + } catch (Exception e) { + e.printStackTrace(); + } + } + +} diff --git a/src/main/java/com/util/PasswordHelper.java b/src/main/java/com/util/PasswordHelper.java index b3da71b..06c41c4 100644 --- a/src/main/java/com/util/PasswordHelper.java +++ b/src/main/java/com/util/PasswordHelper.java @@ -32,6 +32,15 @@ public void setAlgorithmName(String algorithmName) { public void setHashIterations(int hashIterations) { this.hashIterations = hashIterations; } + + public static void main(String[] args) { + PasswordHelper ph = new PasswordHelper(); + User user = new User(); + user.setUserId("admin"); + user.setPassword("123456"); + ph.encryptPassword(user); + System.out.println(user); + } public void encryptPassword(User user) { diff --git a/src/main/java/com/util/ResultMapUtil.java b/src/main/java/com/util/ResultMapUtil.java new file mode 100644 index 0000000..12d6020 --- /dev/null +++ b/src/main/java/com/util/ResultMapUtil.java @@ -0,0 +1,40 @@ +package com.util; + +import java.util.Map; + +import org.apache.commons.lang.StringUtils; + +import com.google.common.collect.Maps; + +public class ResultMapUtil { + public static Map getSuccessMap() { + return getSuccessMap(null,null); + } + public static Map getSuccessMap(String msg) { + return getSuccessMap(msg,null); + } + public static Map getSuccessMap(Object obj) { + return getSuccessMap(null,obj); + } + public static Map getSuccessMap(String msg,Object obj) { + Map map = Maps.newHashMap(); + map.put("resultCode", Constant.MSG_OK); + map.put("resultMsg", Constant.OK_SYS); + if(!StringUtils.isEmpty(msg)) + map.put("resultMsg", msg); + if(obj!=null) + map.put("data", obj); + return map; + } + public static Map getFailMap() { + return getFailMap(null); + } + public static Map getFailMap(String msg) { + Map map = Maps.newHashMap(); + map.put("resultCode", Constant.MSG_ERROR); + map.put("resultMsg", Constant.ERROR_SYS); + if(!StringUtils.isEmpty(msg)) + map.put("resultMsg", msg); + return map; + } +} diff --git a/src/main/java/com/util/TaskJob.java b/src/main/java/com/util/TaskJob.java deleted file mode 100644 index f9612be..0000000 --- a/src/main/java/com/util/TaskJob.java +++ /dev/null @@ -1,15 +0,0 @@ -package com.util; - -import org.springframework.scheduling.annotation.Scheduled; -import org.springframework.stereotype.Component; - -/** - * Created by c0de8ug on 16-2-15. - */ -//@Component -public class TaskJob { - //@Scheduled(cron = "0 0 0 1 * ?") - public void job() { - TermContainer.update(); - } -} diff --git a/src/main/java/com/util/Term.java b/src/main/java/com/util/Term.java deleted file mode 100644 index 9d24fea..0000000 --- a/src/main/java/com/util/Term.java +++ /dev/null @@ -1,26 +0,0 @@ -package com.util; - - -/** - * Created by c0de8ug on 16-2-15. - */ -public class Term { - String val; - String text; - - public String getVal() { - return val; - } - - public void setVal(String val) { - this.val = val; - } - - public String getText() { - return text; - } - - public void setText(String text) { - this.text = text; - } -} diff --git a/src/main/java/com/util/TermContainer.java b/src/main/java/com/util/TermContainer.java deleted file mode 100644 index 2b8ca70..0000000 --- a/src/main/java/com/util/TermContainer.java +++ /dev/null @@ -1,83 +0,0 @@ -package com.util; - -import java.util.ArrayList; -import java.util.Date; -import java.util.GregorianCalendar; -import java.util.HashMap; -import java.util.List; - -import org.springframework.stereotype.Component; - -/** - * Created by c0de8ug on 16-2-15. - */ -@Component -public class TermContainer { - static List termList; - static Date beginTime; - static HashMap map = new HashMap<>(); - final static String lastTermStr = "上学期"; - final static String nextTermStr = "下学期"; - - String lastSemester = "2,3,4,5,6,7,8"; - String nextSemester = "1,9,10,11,12"; - - TermContainer() { - - - for (String temp : lastSemester.split(",")) { - map.put(temp, lastTermStr); - } - for (String temp : nextSemester.split(",")) { - map.put(temp, nextTermStr); - } - beginTime = new GregorianCalendar(2014,1,1).getTime(); - update(); - } - - public static void update() { - termList = new ArrayList<>(); - - Date today = new Date(); - - - int beginYear = beginTime.getYear(); - int todayYear = today.getYear(); - int count = todayYear - beginYear; - - if (map.get(String.valueOf(today.getMonth())).equals(nextTermStr)) { - Term term = new Term(); - term.setVal(todayYear + "2"); - term.setText(todayYear + nextTermStr); - termList.add(term); - } - Term term = new Term(); - term.setVal(todayYear + "1"); - term.setText(todayYear + lastTermStr); - termList.add(term); - - - for (int i = 0; i < count; i++) { - todayYear--; - term = new Term(); - term.setVal(todayYear + "2"); - term.setText(todayYear + nextTermStr); - termList.add(term); - term = new Term(); - term.setVal(todayYear + "1"); - term.setText(todayYear + lastTermStr); - termList.add(term); - - } - - } - - - public static String now() { - return termList.get(0).getVal(); - } - - public static List getTermList() { - return termList; - } -} diff --git a/src/main/java/com/vm/controller/AgentController.java b/src/main/java/com/vm/controller/AgentController.java new file mode 100644 index 0000000..e4aaa7a --- /dev/null +++ b/src/main/java/com/vm/controller/AgentController.java @@ -0,0 +1,164 @@ +package com.vm.controller; + +import java.beans.PropertyEditorSupport; +import java.io.IOException; +import java.util.List; +import java.util.Map; + +import org.apache.commons.lang.StringUtils; +import org.apache.log4j.Logger; +import org.apache.poi.hssf.usermodel.HSSFWorkbook; +import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import org.apache.shiro.authz.annotation.RequiresPermissions; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.transaction.interceptor.TransactionAspectSupport; +import org.springframework.ui.Model; +import org.springframework.web.bind.WebDataBinder; +import org.springframework.web.bind.annotation.InitBinder; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RequestParam; +import org.springframework.web.bind.annotation.ResponseBody; +import org.springframework.web.multipart.commons.CommonsMultipartFile; + +import com.entity.Agent; +import com.entity.enumeration.AgentLevel; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.system.service.UserBiz; +import com.util.ResultMapUtil; +import com.vm.service.AgentBiz; +import com.vm.service.AreaBiz; + +@Controller +@RequestMapping("agent.do") +public class AgentController { + private Logger log = Logger.getLogger(AgentController.class); + + @Autowired + private AgentBiz agentBiz; + @Autowired + private UserBiz userBiz; + @Autowired + private AreaBiz areaBiz; + + @InitBinder + protected void initBinder(WebDataBinder binder) { + binder.registerCustomEditor(AgentLevel.class, new PropertyEditorSupport(){ + @Override + public void setAsText(String text) throws IllegalArgumentException { + if(!StringUtils.isEmpty(text)) + this.setValue(AgentLevel.valueOf(text)); + } + @Override + public String getAsText() { + AgentLevel value = (AgentLevel)this.getValue(); + return value.name(); + } + }); + } + + @RequiresPermissions("agent:query") + @RequestMapping("agent.view") + public String agentView(Model model) { + return "forward:/agent.do/agent.view/0/10"; + } + + @RequiresPermissions("agent:query") + @RequestMapping("agent.view/{pageNum}/{pageSize}") + public String agentView(Agent agent,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = agentBiz.find(agent); + PageInfo page = new PageInfo(list); + m.addAttribute("agentList", list); + m.addAttribute("page", page); + return "/vm/agent/agent"; + } + + @RequiresPermissions("agent:add") + @RequestMapping("agent_add.view") + public String agentAddView(Model m) { + m.addAttribute("agent", new Agent()); + m.addAttribute("agentLevel", AgentLevel.values()); + m.addAttribute("areaList", areaBiz.find(null)); + m.addAttribute("userList", userBiz.findByRole("agent")); + return "/vm/agent/agent_add"; + } + + @RequiresPermissions("agent:update") + @RequestMapping("agent_update.view") + public String agentUpdateView(Long id,Model m) { + m.addAttribute("agentLevel", AgentLevel.values()); + m.addAttribute("agent",agentBiz.findById(id)); + m.addAttribute("areaList", areaBiz.find(null)); + m.addAttribute("userList", userBiz.findByRole("agent")); + return "/vm/agent/agent_update"; + } + + @RequiresPermissions("agent:add") + @RequestMapping("add") + public String add(Agent agent) { + agentBiz.add(agent); + return "redirect:/agent.do/agent.view"; + } + + @RequiresPermissions("agent:update") + @RequestMapping("update") + public String update(Agent agent) { + agentBiz.update(agent); + return "redirect:/agent.do/agent.view"; + } + + @RequiresPermissions("agent:delete") + @RequestMapping("delete") + public String delete(Long id) { + agentBiz.delete(id); + return "redirect:/agent.do/agent.view"; + } + + + @SuppressWarnings("resource") + @RequiresPermissions("agent:import") + @RequestMapping("import") + @ResponseBody + @Transactional() + public Map imp(@RequestParam("file") CommonsMultipartFile file){ + Workbook wb = null; + try { + boolean isExcel2007 = file.getOriginalFilename().matches("^.+\\.(?i)(xlsx)$"); + if(isExcel2007) { + wb = new XSSFWorkbook(file.getInputStream()); + } else { + wb = new HSSFWorkbook(file.getInputStream()); + } + Sheet sheet = wb.getSheetAt(0); + int rowNum = sheet.getLastRowNum(); + for(int i=1;i<=rowNum;i++) { + Row row = sheet.getRow(i); + String level = row.getCell(0).getStringCellValue(); + AgentLevel agentLevel = AgentLevel.parse(level); + String agentName = row.getCell(1).getStringCellValue(); + if(StringUtils.isEmpty(agentName)) continue; + String area = row.getCell(2).getStringCellValue(); + String openid = row.getCell(3).getStringCellValue(); + Agent agent = new Agent(agentLevel,agentName,area,openid); + + agentBiz.add(agent); + } + } catch(NullPointerException e) { + log.error("上传文件解析失败",e); + TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); + return ResultMapUtil.getFailMap("字段不允许为空"); + } catch (IOException e) { + log.error("上传文件解析失败",e); + return ResultMapUtil.getFailMap(); + } + return ResultMapUtil.getSuccessMap(); + } +} diff --git a/src/main/java/com/vm/controller/AreaController.java b/src/main/java/com/vm/controller/AreaController.java new file mode 100644 index 0000000..3a963dd --- /dev/null +++ b/src/main/java/com/vm/controller/AreaController.java @@ -0,0 +1,76 @@ +package com.vm.controller; + +import java.util.List; + +import org.apache.shiro.authz.annotation.RequiresPermissions; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; + +import com.entity.Area; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.vm.service.AreaBiz; + +@Controller +@RequestMapping("area.do") +public class AreaController { + + @Autowired + private AreaBiz areaBiz; + + @RequiresPermissions("area:query") + @RequestMapping("area.view") + public String areaView(Model model) { + return "forward:/area.do/area.view/0/10"; + } + + @RequiresPermissions("area:query") + @RequestMapping("area.view/{pageNum}/{pageSize}") + public String areaView(Area area,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = areaBiz.find(area); + PageInfo page = new PageInfo(list); + m.addAttribute("areaList", list); + m.addAttribute("page", page); + return "/vm/area/area"; + } + + @RequiresPermissions("area:add") + @RequestMapping("area_add.view") + public String areaAddView(Model m) { + m.addAttribute("area", new Area()); + return "/vm/area/area_add"; + } + + @RequiresPermissions("area:update") + @RequestMapping("area_update.view") + public String areaUpdateView(Long id,Model m) { + m.addAttribute("area",areaBiz.findById(id)); + return "/vm/area/area_update"; + } + + @RequiresPermissions("area:add") + @RequestMapping("add") + public String add(Area area) { + areaBiz.add(area); + return "redirect:/area.do/area.view"; + } + + @RequiresPermissions("area:update") + @RequestMapping("update") + public String update(Area area) { + areaBiz.update(area); + return "redirect:/area.do/area.view"; + } + + @RequiresPermissions("area:delete") + @RequestMapping("delete") + public String delete(Long id) { + areaBiz.delete(id); + return "redirect:/area.do/area.view"; + } +} diff --git a/src/main/java/com/vm/controller/CarController.java b/src/main/java/com/vm/controller/CarController.java index b370350..253efce 100644 --- a/src/main/java/com/vm/controller/CarController.java +++ b/src/main/java/com/vm/controller/CarController.java @@ -1,14 +1,33 @@ package com.vm.controller; +import java.io.IOException; +import java.util.List; +import java.util.Map; + import org.apache.log4j.Logger; +import org.apache.poi.hssf.usermodel.HSSFWorkbook; +import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.transaction.interceptor.TransactionAspectSupport; import org.springframework.ui.Model; +import org.springframework.util.StringUtils; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RequestParam; +import org.springframework.web.bind.annotation.ResponseBody; +import org.springframework.web.multipart.commons.CommonsMultipartFile; import com.entity.Car; import com.entity.Standard; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.util.ResultMapUtil; import com.vm.service.CarBiz; import com.vm.service.StandardBiz; @@ -21,11 +40,22 @@ public class CarController { private CarBiz carBiz; @Autowired private StandardBiz standardBiz; - + @RequiresPermissions("car:query") @RequestMapping("car.view") - public String CarView(Car car,Model m) { - m.addAttribute("carList", carBiz.find(car)); + public String carView(Model model) { + return "forward:/car.do/car.view/0/10"; + } + + @RequiresPermissions("car:query") + @RequestMapping("car.view/{pageNum}/{pageSize}") + public String CarView(Car car,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = carBiz.find(car); + PageInfo page = new PageInfo(list); + m.addAttribute("carList", list); + m.addAttribute("page", page); return "/vm/car/car"; } @@ -64,5 +94,45 @@ public String delete(Long id) { carBiz.delete(id); return "redirect:/car.do/car.view"; } + + @SuppressWarnings("resource") + @RequiresPermissions("car:import") + @RequestMapping("import") + @ResponseBody + @Transactional() + public Map imp(@RequestParam("file") CommonsMultipartFile file){ + Workbook wb = null; + try { + boolean isExcel2007 = file.getOriginalFilename().matches("^.+\\.(?i)(xlsx)$"); + if(isExcel2007) { + wb = new XSSFWorkbook(file.getInputStream()); + } else { + wb = new HSSFWorkbook(file.getInputStream()); + } + Sheet sheet = wb.getSheetAt(0); + int rowNum = sheet.getLastRowNum(); + for(int i=1;i<=rowNum;i++) { + Row row = sheet.getRow(i); + String carId = row.getCell(0).getStringCellValue(); + if(StringUtils.isEmpty(carId)) continue; + Boolean isSale = row.getCell(1).getBooleanCellValue(); + Integer high = (int) row.getCell(2).getNumericCellValue(); + Integer length = (int) row.getCell(3).getNumericCellValue(); + Integer wide = (int) row.getCell(4).getNumericCellValue(); + Integer weight = (int) row.getCell(5).getNumericCellValue(); + + Car car = new Car(carId,isSale,high,length,wide,weight); + carBiz.add(car); + } + } catch(NullPointerException e) { + log.error("上传文件解析失败",e); + TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); + return ResultMapUtil.getFailMap("字段不允许为空"); + } catch (IOException e) { + log.error("上传文件解析失败",e); + return ResultMapUtil.getFailMap(); + } + return ResultMapUtil.getSuccessMap(); + } } diff --git a/src/main/java/com/vm/controller/OrderController.java b/src/main/java/com/vm/controller/OrderController.java new file mode 100644 index 0000000..f4902aa --- /dev/null +++ b/src/main/java/com/vm/controller/OrderController.java @@ -0,0 +1,173 @@ +package com.vm.controller; + +import java.beans.PropertyEditorSupport; +import java.io.IOException; +import java.util.List; +import java.util.Map; + +import org.apache.commons.lang.StringUtils; +import org.apache.log4j.Logger; +import org.apache.poi.hssf.usermodel.HSSFWorkbook; +import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import org.apache.shiro.authz.annotation.RequiresPermissions; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.transaction.interceptor.TransactionAspectSupport; +import org.springframework.ui.Model; +import org.springframework.ui.ModelMap; +import org.springframework.web.bind.WebDataBinder; +import org.springframework.web.bind.annotation.InitBinder; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RequestParam; +import org.springframework.web.bind.annotation.ResponseBody; +import org.springframework.web.multipart.commons.CommonsMultipartFile; + +import com.entity.Agent; +import com.entity.Car; +import com.entity.Order; +import com.entity.enumeration.OrderType; +import com.entity.enumeration.Status; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.util.ResultMapUtil; +import com.vm.service.AgentBiz; +import com.vm.service.CarBiz; +import com.vm.service.OrderBiz; + +@Controller +@RequestMapping("order.do") +public class OrderController { + private Logger log = Logger.getLogger(OrderController.class); + + @Autowired + private OrderBiz orderBiz; + @Autowired + private CarBiz carBiz; + @Autowired + private AgentBiz agentBiz; + + + @InitBinder + protected void initBinder(WebDataBinder binder) { + binder.registerCustomEditor(OrderType.class, new PropertyEditorSupport(){ + @Override + public void setAsText(String text) throws IllegalArgumentException { + if(!StringUtils.isEmpty(text)) + this.setValue(OrderType.valueOf(text)); + } + @Override + public String getAsText() { + OrderType value = (OrderType)this.getValue(); + return value.name(); + } + }); + } + + @RequiresPermissions("order:query") + @RequestMapping("order.view") + public String orderView(Model model) { + return "forward:/order.do/order.view/0/10"; + } + + @RequiresPermissions("order:query") + @RequestMapping("order.view/{pageNum}/{pageSize}") + public String orderView(Order order,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = orderBiz.find(order); + PageInfo page = new PageInfo(list); + m.addAttribute("orderList", list); + m.addAttribute("page", page); + return "/vm/order/order"; + } + + @RequestMapping("external/order_add.view") + public String orderAddView(ModelMap m) { + String openid = (String) m.get("openid"); + String orderType = (String) m.get("orderType"); + if(StringUtils.isEmpty(openid)) { + openid = "test"; + m.put("openid", openid); + } + if(StringUtils.isEmpty(orderType)) { + orderType = OrderType.DISTRIBUTION.name(); + m.put("orderType", orderType); + } + Agent agent = agentBiz.findByOpenId(openid); + List carList = carBiz.findByLevel(agent.getLevel()); + m.put("carList", carList); + return "/vm/order/external_order_add"; + } + + @RequestMapping("external/add") + public String add(Order order) { + order.setStatus(Status.START); + orderBiz.add(order); + return "/vm/order/external_order_add_success"; + } + + @RequiresPermissions("order:update") + @RequestMapping("order_update.view") + public String orderUpdateView(Long id,Model m) { + m.addAttribute("order",orderBiz.findById(id)); + return "/vm/order/order_update"; + } + + + @RequiresPermissions("order:update") + @RequestMapping("update") + public String update(Order order) { + orderBiz.update(order); + return "redirect:/order.do/order.view"; + } + + @RequiresPermissions("order:delete") + @RequestMapping("delete") + public String delete(Long id) { + orderBiz.delete(id); + return "redirect:/order.do/order.view"; + } + + + @SuppressWarnings("resource") + @RequiresPermissions("order:import") + @RequestMapping("import") + @ResponseBody + @Transactional() + public Map imp(@RequestParam("file") CommonsMultipartFile file){ + Workbook wb = null; + try { + boolean isExcel2007 = file.getOriginalFilename().matches("^.+\\.(?i)(xlsx)$"); + if(isExcel2007) { + wb = new XSSFWorkbook(file.getInputStream()); + } else { + wb = new HSSFWorkbook(file.getInputStream()); + } + Sheet sheet = wb.getSheetAt(0); + int rowNum = sheet.getLastRowNum(); + for(int i=1;i<=rowNum;i++) { + Row row = sheet.getRow(i); + String level = row.getCell(0).getStringCellValue(); + String orderName = row.getCell(1).getStringCellValue(); + if(StringUtils.isEmpty(orderName)) continue; + String area = row.getCell(2).getStringCellValue(); + Order order = new Order(); + + orderBiz.add(order); + } + } catch(NullPointerException e) { + log.error("上传文件解析失败",e); + TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); + return ResultMapUtil.getFailMap("字段不允许为空"); + } catch (IOException e) { + log.error("上传文件解析失败",e); + return ResultMapUtil.getFailMap(); + } + return ResultMapUtil.getSuccessMap(); + } +} diff --git a/src/main/java/com/vm/controller/ProcurementController.java b/src/main/java/com/vm/controller/ProcurementController.java new file mode 100644 index 0000000..5af951a --- /dev/null +++ b/src/main/java/com/vm/controller/ProcurementController.java @@ -0,0 +1,95 @@ +package com.vm.controller; + +import java.util.List; +import java.util.Map; + +import javax.servlet.http.HttpServletRequest; + +import org.apache.log4j.Logger; +import org.apache.shiro.authz.annotation.RequiresPermissions; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.ResponseBody; + +import com.entity.Procurement; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.vm.service.FileUploadBiz; +import com.vm.service.ProcurementBiz; + +@Controller +@RequestMapping("procurement.do") +public class ProcurementController { + private Logger log = Logger.getLogger(ProcurementController.class); + + @Autowired + private ProcurementBiz procBiz; + @Autowired + private FileUploadBiz fileUpload; + + @RequiresPermissions("procurement:query") + @RequestMapping("procurement.view") + public String ProcurementViewForword(Model model) { + return "forward:/procurement.do/procurement.view/0/10"; + } + + @RequiresPermissions("procurement:query") + @RequestMapping("procurement.view/{pageNum}/{pageSize}") + public String ProcurementView(Procurement procurement,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + + PageHelper.startPage(pageNum, pageSize); + List list = procBiz.find(procurement); + PageInfo page = new PageInfo(list); + m.addAttribute("procurementList", list); + m.addAttribute("page", page); + return "/vm/procurement/procurement"; + } + + @RequiresPermissions("procurement:add") + @RequestMapping("procurement_add.view") + public String procurementAddView(Model m) { + + return "/vm/procurement/procurement_add"; + } + @RequiresPermissions("procurement:add") + @RequestMapping("add") + public String add(Procurement procurement) { + procBiz.add(procurement); + return "redirect:/procurement.do/procurement.view"; + } + + @RequiresPermissions("procurement:update") + @RequestMapping("procurement_update.view") + public String procurementUpdateView(Long id,Model m) { + m.addAttribute("procurement",procBiz.findById(id)); + return "/vm/procurement/procurement_update"; + } + + @RequiresPermissions("procurement:update") + @RequestMapping("update") + public String update(Procurement procurement) { + procBiz.update(procurement); + return "redirect:/procurement.do/procurement.view"; + } + + @RequiresPermissions("procurement:delete") + @RequestMapping("delete") + public String delete(Long id) { + procBiz.delete(id); + return "redirect:/procurement.do/procurement.view"; + } + + @RequiresPermissions("procurement:import") + @RequestMapping("import") + @ResponseBody + @Transactional() + public Map imp(HttpServletRequest request){ + + return fileUpload.fileUploadFile(request); + } +} diff --git a/src/main/java/com/vm/controller/StandardController.java b/src/main/java/com/vm/controller/StandardController.java index 206d764..dbe491a 100644 --- a/src/main/java/com/vm/controller/StandardController.java +++ b/src/main/java/com/vm/controller/StandardController.java @@ -1,12 +1,17 @@ package com.vm.controller; +import java.util.List; + import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import com.entity.Standard; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; import com.vm.service.StandardBiz; @Controller @@ -15,11 +20,22 @@ public class StandardController { @Autowired private StandardBiz standardBiz; - + @RequiresPermissions("standard:query") @RequestMapping("standard.view") - public String standardView(Standard standard,Model m) { - m.addAttribute("standardList", standardBiz.find(standard)); + public String standardView(Model model) { + return "forward:/standard.do/standard.view/0/10"; + } + + @RequiresPermissions("standard:query") + @RequestMapping("standard.view/{pageNum}/{pageSize}") + public String standardView(Standard standard,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = standardBiz.find(standard); + PageInfo page = new PageInfo(list); + m.addAttribute("standardList", list); + m.addAttribute("page", page); return "/vm/standard/standard"; } diff --git a/src/main/java/com/vm/controller/UploadController.java b/src/main/java/com/vm/controller/UploadController.java new file mode 100644 index 0000000..a6b877c --- /dev/null +++ b/src/main/java/com/vm/controller/UploadController.java @@ -0,0 +1,95 @@ +package com.vm.controller; + +import java.util.List; +import java.util.Map; + +import javax.servlet.http.HttpServletRequest; + +import org.apache.log4j.Logger; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.ResponseBody; + +import com.entity.FileInfo; +import com.util.ResultMapUtil; +import com.vm.service.FileUploadBiz; + + +@Controller +@RequestMapping("upload.do") +public class UploadController { + private Logger log = Logger.getLogger(UploadController.class); + + @Autowired + private FileUploadBiz fileUpload; + + + /** + * 上传文件 + * + * @param request + * @return + */ + @RequestMapping("file") + @ResponseBody + public Map uploadFile(HttpServletRequest request) { + return fileUpload.fileUploadFile(request); + } + + /** + * 上传图片 + * + * @param request + * @return + */ + @RequestMapping("image") + @ResponseBody + public Map uploadImage(HttpServletRequest request) { + return fileUpload.fileUploadImage(request); + } + + /** + * 多文件上传 + * + * @param request + * @return + */ + @RequestMapping("multiple") + @ResponseBody + public Map uploadMultiple(HttpServletRequest request) { + return fileUpload.uploadMultiple(request); + } + + @RequestMapping("delete") + @ResponseBody + public Map delete(Long id) { + try { + fileUpload.delete(id); + } catch(Exception e) { + log.error("DeleteError",e); + return ResultMapUtil.getFailMap(); + } + return ResultMapUtil.getSuccessMap(); + } + + + @RequestMapping("query") + @ResponseBody + public Map query(Long id) { + FileInfo fileInfo = fileUpload.query(id); + return ResultMapUtil.getSuccessMap(fileInfo); + } + + @RequestMapping("queryByIds") + @ResponseBody + public Map query(String ids) { + try { + List list = fileUpload.query(ids); + return ResultMapUtil.getSuccessMap(list); + } catch(Exception e) { + log.error("QueryError",e); + return ResultMapUtil.getFailMap(); + } + } +} diff --git a/src/main/java/com/vm/controller/VendorController.java b/src/main/java/com/vm/controller/VendorController.java new file mode 100644 index 0000000..bc4de71 --- /dev/null +++ b/src/main/java/com/vm/controller/VendorController.java @@ -0,0 +1,76 @@ +package com.vm.controller; + +import java.util.List; + +import org.apache.shiro.authz.annotation.RequiresPermissions; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Controller; +import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.PathVariable; +import org.springframework.web.bind.annotation.RequestMapping; + +import com.entity.Vendor; +import com.github.pagehelper.PageHelper; +import com.github.pagehelper.PageInfo; +import com.vm.service.VendorBiz; + +@Controller +@RequestMapping("vendor.do") +public class VendorController { + + @Autowired + private VendorBiz vendorBiz; + + @RequiresPermissions("vendor:query") + @RequestMapping("vendor.view") + public String vendorView(Model model) { + return "forward:/vendor.do/vendor.view/0/10"; + } + + @RequiresPermissions("vendor:query") + @RequestMapping("vendor.view/{pageNum}/{pageSize}") + public String vendorView(Vendor vendor,Model m,@PathVariable("pageNum") int pageNum, + @PathVariable("pageSize") int pageSize) { + PageHelper.startPage(pageNum, pageSize); + List list = vendorBiz.find(vendor); + PageInfo page = new PageInfo(list); + m.addAttribute("vendorList", list); + m.addAttribute("page", page); + return "/vm/vendor/vendor"; + } + + @RequiresPermissions("vendor:add") + @RequestMapping("vendor_add.view") + public String vendorAddView(Model m) { + m.addAttribute("vendor", new Vendor()); + return "/vm/vendor/vendor_add"; + } + + @RequiresPermissions("vendor:update") + @RequestMapping("vendor_update.view") + public String vendorUpdateView(Long id,Model m) { + m.addAttribute("vendor",vendorBiz.findById(id)); + return "/vm/vendor/vendor_update"; + } + + @RequiresPermissions("vendor:add") + @RequestMapping("add") + public String add(Vendor vendor) { + vendorBiz.add(vendor); + return "redirect:/vendor.do/vendor.view"; + } + + @RequiresPermissions("vendor:update") + @RequestMapping("update") + public String update(Vendor vendor) { + vendorBiz.update(vendor); + return "redirect:/vendor.do/vendor.view"; + } + + @RequiresPermissions("vendor:delete") + @RequestMapping("delete") + public String delete(Long id) { + vendorBiz.delete(id); + return "redirect:/vendor.do/vendor.view"; + } +} diff --git a/src/main/java/com/vm/dao/AgentDao.java b/src/main/java/com/vm/dao/AgentDao.java new file mode 100644 index 0000000..819f364 --- /dev/null +++ b/src/main/java/com/vm/dao/AgentDao.java @@ -0,0 +1,19 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.Agent; + +public interface AgentDao { + public List find(Agent agent); + + public Agent findById(Long id); + + public void add(Agent Agent); + + public void update(Agent agent); + + public void delete(Long id); + + public Agent findByOpenId(String id); +} diff --git a/src/main/java/com/vm/dao/AreaDao.java b/src/main/java/com/vm/dao/AreaDao.java new file mode 100644 index 0000000..1da5720 --- /dev/null +++ b/src/main/java/com/vm/dao/AreaDao.java @@ -0,0 +1,17 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.Area; + +public interface AreaDao { + public List find(Area area); + + public Area findById(Long id); + + public void add(Area area); + + public void update(Area area); + + public void delete(Long id); +} diff --git a/src/main/java/com/vm/dao/FileUploadDao.java b/src/main/java/com/vm/dao/FileUploadDao.java new file mode 100644 index 0000000..1298653 --- /dev/null +++ b/src/main/java/com/vm/dao/FileUploadDao.java @@ -0,0 +1,13 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.FileInfo; + +public interface FileUploadDao { + public void add(FileInfo fileInfo); + public void delete(Long id); + public FileInfo findById(Long id); + public List findAll(); + public List findByIds(List list); +} diff --git a/src/main/java/com/vm/dao/OrderDao.java b/src/main/java/com/vm/dao/OrderDao.java new file mode 100644 index 0000000..8c43bf7 --- /dev/null +++ b/src/main/java/com/vm/dao/OrderDao.java @@ -0,0 +1,18 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.Order; + +public interface OrderDao { + public List find(Order order); + + public Order findById(Long id); + + public void add(Order order); + + public void update(Order order); + + public void delete(Long id); + +} diff --git a/src/main/java/com/vm/dao/ProcurementDao.java b/src/main/java/com/vm/dao/ProcurementDao.java new file mode 100644 index 0000000..fde75df --- /dev/null +++ b/src/main/java/com/vm/dao/ProcurementDao.java @@ -0,0 +1,18 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.Procurement; + +public interface ProcurementDao { + public List find(Procurement procurement); + + public Procurement findById(Long id); + + public void add(Procurement procurement); + + public void update(Procurement procurement); + + public void delete(Long id); + +} diff --git a/src/main/java/com/vm/dao/VendorDao.java b/src/main/java/com/vm/dao/VendorDao.java new file mode 100644 index 0000000..a62b78c --- /dev/null +++ b/src/main/java/com/vm/dao/VendorDao.java @@ -0,0 +1,17 @@ +package com.vm.dao; + +import java.util.List; + +import com.entity.Vendor; + +public interface VendorDao { + public List find(Vendor vendor); + + public Vendor findById(Long id); + + public void add(Vendor vendor); + + public void update(Vendor vendor); + + public void delete(Long id); +} diff --git a/src/main/java/com/vm/service/AgentBiz.java b/src/main/java/com/vm/service/AgentBiz.java new file mode 100644 index 0000000..a4a065e --- /dev/null +++ b/src/main/java/com/vm/service/AgentBiz.java @@ -0,0 +1,19 @@ +package com.vm.service; + +import java.util.List; + +import com.entity.Agent; + +public interface AgentBiz { + public List find(Agent agent); + + public void add(Agent agent); + + public void update(Agent agent); + + public void delete(Long id); + + public Agent findById(Long id); + + public Agent findByOpenId(String id); +} diff --git a/src/main/java/com/vm/service/AreaBiz.java b/src/main/java/com/vm/service/AreaBiz.java new file mode 100644 index 0000000..276bf4b --- /dev/null +++ b/src/main/java/com/vm/service/AreaBiz.java @@ -0,0 +1,17 @@ +package com.vm.service; + +import java.util.List; + +import com.entity.Area; + +public interface AreaBiz { + public List find(Area area); + + public void add(Area area); + + public void update(Area area); + + public void delete(Long id); + + public Area findById(Long id); +} diff --git a/src/main/java/com/vm/service/CarBiz.java b/src/main/java/com/vm/service/CarBiz.java index 28a0905..484cd83 100644 --- a/src/main/java/com/vm/service/CarBiz.java +++ b/src/main/java/com/vm/service/CarBiz.java @@ -3,6 +3,7 @@ import java.util.List; import com.entity.Car; +import com.entity.enumeration.AgentLevel; public interface CarBiz { public List find(Car car); @@ -15,5 +16,5 @@ public interface CarBiz { public Car findById(Long id); - + public List findByLevel(AgentLevel level); } diff --git a/src/main/java/com/vm/service/FileUploadBiz.java b/src/main/java/com/vm/service/FileUploadBiz.java new file mode 100644 index 0000000..f370061 --- /dev/null +++ b/src/main/java/com/vm/service/FileUploadBiz.java @@ -0,0 +1,57 @@ +package com.vm.service; + +import java.util.List; +import java.util.Map; + +import javax.servlet.http.HttpServletRequest; + +import com.entity.FileInfo; + +public interface FileUploadBiz { + + /** + * 上传文件 + * + * @param request + * @param type + * @return + */ + public abstract Map fileUploadFile(HttpServletRequest request); + + /** + * 上传图片 + * + * @param request + * @param category + * @return + */ + public abstract Map fileUploadImage(HttpServletRequest request); + + /** + * 文件上传 + * + * @param tenantCode + * @param userAccount + * @param request + * @param type + * @return + */ + public abstract Map fileUpload(HttpServletRequest request, String allowTypes); + + /** + * 上传文件 + * + * @param request + * @param category + * @param type + * @return + */ + public abstract Map uploadMultiple(HttpServletRequest request); + + public abstract void delete(Long id); + + public abstract FileInfo query(Long id); + + public abstract List query(String ids); + +} \ No newline at end of file diff --git a/src/main/java/com/vm/service/OrderBiz.java b/src/main/java/com/vm/service/OrderBiz.java new file mode 100644 index 0000000..19e6226 --- /dev/null +++ b/src/main/java/com/vm/service/OrderBiz.java @@ -0,0 +1,19 @@ +package com.vm.service; + +import java.util.List; + +import com.entity.Order; + +public interface OrderBiz { + public List find(Order order); + + public void add(Order order); + + public void update(Order order); + + public void delete(Long id); + + public Order findById(Long id); + + +} diff --git a/src/main/java/com/vm/service/ProcurementBiz.java b/src/main/java/com/vm/service/ProcurementBiz.java new file mode 100644 index 0000000..3dd502a --- /dev/null +++ b/src/main/java/com/vm/service/ProcurementBiz.java @@ -0,0 +1,20 @@ +package com.vm.service; + +import java.util.List; + +import com.entity.Car; +import com.entity.Procurement; + +public interface ProcurementBiz { + public List find(Procurement procurement); + + public void add(Procurement procurement); + + public void update(Procurement procurement); + + public void delete(Long id); + + public Procurement findById(Long id); + + +} diff --git a/src/main/java/com/vm/service/VendorBiz.java b/src/main/java/com/vm/service/VendorBiz.java new file mode 100644 index 0000000..8d8cba6 --- /dev/null +++ b/src/main/java/com/vm/service/VendorBiz.java @@ -0,0 +1,17 @@ +package com.vm.service; + +import java.util.List; + +import com.entity.Vendor; + +public interface VendorBiz { + public List find(Vendor vendor); + + public void add(Vendor vendor); + + public void update(Vendor vendor); + + public void delete(Long id); + + public Vendor findById(Long vendor); +} diff --git a/src/main/java/com/vm/service/impl/AgentBizImpl.java b/src/main/java/com/vm/service/impl/AgentBizImpl.java new file mode 100644 index 0000000..2eeeb68 --- /dev/null +++ b/src/main/java/com/vm/service/impl/AgentBizImpl.java @@ -0,0 +1,59 @@ +package com.vm.service.impl; + +import java.util.List; + +import org.apache.commons.lang.StringUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import com.entity.Agent; +import com.entity.User; +import com.system.dao.UserDao; +import com.vm.dao.AgentDao; +import com.vm.service.AgentBiz; + +@Service +public class AgentBizImpl implements AgentBiz { + @Autowired + private AgentDao AgentDao; + @Autowired + private UserDao userDao; + + public List find(Agent agent) { + List list = AgentDao.find(agent); + for(Agent entry : list) { + if(StringUtils.isEmpty(entry.getUserIdsStr())) continue; + StringBuffer buff = new StringBuffer(); + for(String uid : entry.getUserIds()) { + User user = userDao.findById(uid); + buff.append(user.getUsername()).append(','); + } + if(buff.length()!=0) buff.deleteCharAt(buff.length()-1); + entry.setUsernames(buff.toString()); + } + return list; + } + + @Override + public Agent findById(Long id) { + return AgentDao.findById(id); + } + + @Override + public Agent findByOpenId(String id) { + return AgentDao.findByOpenId(id); + } + + public void add(Agent agent) { + AgentDao.add(agent); + } + + public void update(Agent agent) { + AgentDao.update(agent); + } + + public void delete(Long AgentId) { + AgentDao.delete(AgentId); + } + +} diff --git a/src/main/java/com/vm/service/impl/AreaBizImpl.java b/src/main/java/com/vm/service/impl/AreaBizImpl.java new file mode 100644 index 0000000..5bded8e --- /dev/null +++ b/src/main/java/com/vm/service/impl/AreaBizImpl.java @@ -0,0 +1,38 @@ +package com.vm.service.impl; + +import java.util.List; + +import javax.annotation.Resource; + +import org.springframework.stereotype.Service; + +import com.entity.Area; +import com.vm.dao.AreaDao; +import com.vm.service.AreaBiz; + +@Service +public class AreaBizImpl implements AreaBiz { + @Resource + private AreaDao areaDao; + + public List find(Area area) { + return areaDao.find(area); + } + + @Override + public Area findById(Long id) { + return areaDao.findById(id); + } + + public void add(Area area) { + areaDao.add(area); + } + + public void update(Area area) { + areaDao.update(area); + } + + public void delete(Long areaId) { + areaDao.delete(areaId); + } +} diff --git a/src/main/java/com/vm/service/impl/CarBizImpl.java b/src/main/java/com/vm/service/impl/CarBizImpl.java index 94ad2ee..b0abb5f 100644 --- a/src/main/java/com/vm/service/impl/CarBizImpl.java +++ b/src/main/java/com/vm/service/impl/CarBizImpl.java @@ -7,6 +7,7 @@ import org.springframework.stereotype.Service; import com.entity.Car; +import com.entity.enumeration.AgentLevel; import com.vm.dao.CarDao; import com.vm.service.CarBiz; @@ -20,6 +21,12 @@ public List find(Car car) { } @Override + public List findByLevel(AgentLevel level) { + //TODO 根据客户等级查询车辆 + return carDao.find(new Car()); + } + + @Override public Car findById(Long id) { return carDao.findById(id); } diff --git a/src/main/java/com/vm/service/impl/FileUploadBizImpl.java b/src/main/java/com/vm/service/impl/FileUploadBizImpl.java new file mode 100644 index 0000000..4e2dd3d --- /dev/null +++ b/src/main/java/com/vm/service/impl/FileUploadBizImpl.java @@ -0,0 +1,270 @@ +package com.vm.service.impl; + +import java.io.IOException; +import java.net.URLEncoder; +import java.text.SimpleDateFormat; +import java.util.ArrayList; +import java.util.Date; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Properties; +import java.util.UUID; + +import javax.annotation.PostConstruct; +import javax.servlet.http.HttpServletRequest; + +import org.apache.commons.lang3.StringUtils; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.web.multipart.MultipartFile; +import org.springframework.web.multipart.MultipartHttpServletRequest; +import org.springframework.web.multipart.commons.CommonsMultipartResolver; + +import com.enterprisedt.net.ftp.FTPException; +import com.entity.FileInfo; +import com.google.common.collect.Lists; +import com.util.FtpClient; +import com.util.ResultMapUtil; +import com.vm.dao.FileUploadDao; +import com.vm.service.FileUploadBiz; + +/** + * 多文件上传 + * + */ +@Service +public class FileUploadBizImpl implements FileUploadBiz { + + private String ip; + private String readurl; + private String rootDir; + private String username; + private String password; + private static String allowFileTypes; + private static String allowImageTypes; + private static final String CONFIG_FILE_NAME = "upload.properties"; + private Log logger = LogFactory.getLog(this.getClass()); + + @Autowired + private FileUploadDao fileUploadDao; + + @PostConstruct + private void init() { + Properties properties = new Properties(); + try { + properties.load(FileUploadBizImpl.class.getClassLoader() + .getResourceAsStream(CONFIG_FILE_NAME)); + allowFileTypes = properties.getProperty("allowFileTypes"); + allowFileTypes += allowFileTypes.toLowerCase(); + allowImageTypes = properties.getProperty("allowImageTypes"); + allowImageTypes += allowImageTypes.toLowerCase(); + this.ip = properties.getProperty("ftp.ip"); + this.username = properties.getProperty("ftp.username"); + this.password = properties.getProperty("ftp.password"); + this.readurl = properties.getProperty("ftp.readurl"); + this.rootDir = properties.getProperty("ftp.root"); + } catch (Exception e) { + logger.error("加载配置文件出错!" + e.getMessage()); + } + } + + /* (non-Javadoc) + * @see com.vm.service.impl.FileUploadBiz#fileUploadFile(javax.servlet.http.HttpServletRequest, com.entity.enumeration.FtpUploadType, java.lang.String) + */ + @Override + public Map fileUploadFile(HttpServletRequest request) { + return this.fileUpload(request, allowFileTypes); + } + + /* (non-Javadoc) + * @see com.vm.service.impl.FileUploadBiz#fileUploadImage(javax.servlet.http.HttpServletRequest, com.entity.enumeration.FtpUploadType, java.lang.String) + */ + @Override + public Map fileUploadImage(HttpServletRequest request) { + return this.fileUpload(request, allowImageTypes); + } + + /* (non-Javadoc) + * @see com.vm.service.impl.FileUploadBiz#fileUpload(javax.servlet.http.HttpServletRequest, com.entity.enumeration.FtpUploadType, java.lang.String, java.lang.String) + */ + @Override + public Map fileUpload(HttpServletRequest request, String allowTypes) { + Map msg = null; + try { + // 上传文件的解析器 + CommonsMultipartResolver mutiparRe = new CommonsMultipartResolver(); + if (mutiparRe.isMultipart(request)) { + MultipartHttpServletRequest mhr = (MultipartHttpServletRequest) request; + + Iterator it = mhr.getFileNames(); + if (it.hasNext()) { + MultipartFile mf = mhr.getFile(it.next()); + if (mf != null) { + String resFileName = mf.getOriginalFilename(); + String date = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()); + String dateDir = new SimpleDateFormat("yyyy-MM-dd").format(new Date()); + String fileName = rename(resFileName); + String fileType = fileName.substring(fileName.lastIndexOf(".") + 1); + String filePath = this.rootDir + "/" +dateDir; + + if (StringUtils.isEmpty(allowTypes) + || allowTypes.indexOf(fileType) > -1) { + FtpClient client = null; + try { + // 上传ftp + client = getFtpCilent(filePath); + fileName = URLEncoder.encode(fileName, "utf-8"); + client.uploadFile(mf.getInputStream(), fileName); + FileInfo file = new FileInfo(); + file.setFileName(fileName); + file.setFilePath(this.readurl + filePath + "/" + fileName); + file.setFileType(fileType); + file.setUploadTime(date); + file.setOriginalFilename(resFileName); + + fileUploadDao.add(file); + + msg = ResultMapUtil.getSuccessMap(file); + } catch (Exception e) { + msg = ResultMapUtil.getFailMap("上传失败:" + e.getMessage()); + logger.error("上传失败:" + e.getMessage()); + } finally { + if (client != null) + client.close(); + } + } else { + msg = ResultMapUtil.getFailMap("上传失败:非法的文件类型,目前只支持" + allowTypes + "类型"); + } + } else { + msg = ResultMapUtil.getFailMap("上传失败:无效文件"); + } + } else { + msg = ResultMapUtil.getFailMap("上传失败:无效文件"); + } + } else { + msg = ResultMapUtil.getFailMap("上传失败:请求类型错误"); + } + } catch (Exception e) { + msg = ResultMapUtil.getFailMap("上传失败:" + e.getMessage()); + logger.error("上传失败:", e); + } + return msg; + } + + @Override + public Map uploadMultiple(HttpServletRequest request) { + Map msg = null; + FtpClient client = null; + try { + // 上传文件的解析器 + CommonsMultipartResolver mutiparRe = new CommonsMultipartResolver(); + if (mutiparRe.isMultipart(request)) { + MultipartHttpServletRequest mhr = (MultipartHttpServletRequest) request; + + Iterator it = mhr.getFileNames(); + List fileInfo = new ArrayList(); + if(it.hasNext()){ + client = getFtpCilent(""); + while (it.hasNext()) { + FileInfo file = new FileInfo(); + try { + MultipartFile mf = mhr.getFile(it.next()); + if (mf != null) { + file.setUuid(mf.getName()); + String date = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()); + String dateDir = new SimpleDateFormat("yyyy-MM-dd").format(new Date()); + String resFileName = mf.getOriginalFilename(); + String fileName = rename(resFileName); + String fileType = fileName.substring(fileName.lastIndexOf(".") + 1); + String filePath = this.rootDir + "/" +dateDir; + client.changeDir(filePath); + + fileName = URLEncoder.encode(fileName, "utf-8"); + if(StringUtils.isNotEmpty(fileName)){ + //解决中文无法访问的问题 + fileName = fileName.replace("%","-"); + } + + client.uploadFile(mf.getInputStream(), fileName); + file.setFileName(fileName); + file.setFilePath(this.readurl + filePath + "/" + fileName); + file.setFileType(fileType); + file.setUploadTime(date); + file.setOriginalFilename(resFileName); + + fileUploadDao.add(file); + + fileInfo.add(file); + } else { + msg = ResultMapUtil.getFailMap("上传失败:无效文件"); + } + } catch (Exception e) { + msg = ResultMapUtil.getFailMap("上传失败:无效文件"); + logger.error("上传失败:" + e.getMessage()); + } + } + msg = ResultMapUtil.getSuccessMap(fileInfo); + }else { + msg = ResultMapUtil.getFailMap("上传失败:无效文件"); + } + }else { + msg = ResultMapUtil.getFailMap("上传失败:请求类型错误"); + } + } catch (Exception e) { + msg = ResultMapUtil.getFailMap("上传失败:" + e.getMessage()); + logger.error("上传失败:", e); + }finally { + if (client != null) + client.close(); + } + return msg; + } + + @Override + public void delete(Long id) { + fileUploadDao.delete(id); + } + + @Override + public FileInfo query(Long id) { + return fileUploadDao.findById(id); + } + + @Override + public List query(String ids) { + if(StringUtils.isEmpty(ids)) { + return Lists.newArrayList(); + } + List list = Lists.newArrayList(); + for(String id : ids.split(",")) { + list.add(Long.parseLong(id)); + } + return fileUploadDao.findByIds(list); + } + + public FtpClient getFtpCilent(String filePath) throws IOException, FTPException { + FtpClient client = new FtpClient(); + client.connectServer(this.ip, this.username, this.password); + client.changeDir(filePath); + return client; + } + + public String rename(String name) { + String uustr = UUID.randomUUID().toString(); + if (name.indexOf(".") != -1) { + uustr += name.substring(name.lastIndexOf(".")); + } + return uustr; + } + + public static String getAllowFileTypes() { + return allowFileTypes; + } + + public static String getAllowImageTypes() { + return allowImageTypes; + } +} \ No newline at end of file diff --git a/src/main/java/com/vm/service/impl/OrderBizImpl.java b/src/main/java/com/vm/service/impl/OrderBizImpl.java new file mode 100644 index 0000000..b50673e --- /dev/null +++ b/src/main/java/com/vm/service/impl/OrderBizImpl.java @@ -0,0 +1,37 @@ +package com.vm.service.impl; + +import java.util.List; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import com.entity.Order; +import com.vm.dao.OrderDao; +import com.vm.service.OrderBiz; + +@Service +public class OrderBizImpl implements OrderBiz { + @Autowired + private OrderDao orderDao; + + public List find(Order order) { + return orderDao.find(order); + } + + public Order findById(Long id) { + return orderDao.findById(id); + } + + public void add(Order order) { + orderDao.add(order); + } + + public void update(Order order) { + orderDao.update(order); + } + + public void delete(Long orderId) { + orderDao.delete(orderId); + } + +} diff --git a/src/main/java/com/vm/service/impl/ProcurementBizImpl.java b/src/main/java/com/vm/service/impl/ProcurementBizImpl.java new file mode 100644 index 0000000..39cc154 --- /dev/null +++ b/src/main/java/com/vm/service/impl/ProcurementBizImpl.java @@ -0,0 +1,39 @@ +package com.vm.service.impl; + +import java.util.List; + +import javax.annotation.Resource; + +import org.springframework.stereotype.Service; + +import com.entity.Procurement; +import com.vm.dao.ProcurementDao; +import com.vm.service.ProcurementBiz; + +@Service +public class ProcurementBizImpl implements ProcurementBiz { + @Resource + private ProcurementDao procDao; + + public List find(Procurement procurement) { + return procDao.find(procurement); + } + + @Override + public Procurement findById(Long id) { + return procDao.findById(id); + } + + public void add(Procurement procurement) { + procDao.add(procurement); + } + + public void update(Procurement procurement) { + procDao.update(procurement); + } + + public void delete(Long carId) { + procDao.delete(carId); + } + +} diff --git a/src/main/java/com/vm/service/impl/StandardBizImpl.java b/src/main/java/com/vm/service/impl/StandardBizImpl.java index 0cc5214..35fb640 100644 --- a/src/main/java/com/vm/service/impl/StandardBizImpl.java +++ b/src/main/java/com/vm/service/impl/StandardBizImpl.java @@ -10,10 +10,6 @@ import com.vm.dao.StandardDao; import com.vm.service.StandardBiz; -/** - * Created by c0de8ug on 16-2-11. - */ - @Service public class StandardBizImpl implements StandardBiz { @Resource diff --git a/src/main/java/com/vm/service/impl/VendorBizImpl.java b/src/main/java/com/vm/service/impl/VendorBizImpl.java new file mode 100644 index 0000000..6c76d35 --- /dev/null +++ b/src/main/java/com/vm/service/impl/VendorBizImpl.java @@ -0,0 +1,38 @@ +package com.vm.service.impl; + +import java.util.List; + +import javax.annotation.Resource; + +import org.springframework.stereotype.Service; + +import com.entity.Vendor; +import com.vm.dao.VendorDao; +import com.vm.service.VendorBiz; + +@Service +public class VendorBizImpl implements VendorBiz { + @Resource + private VendorDao vendorDao; + + public List find(Vendor vendor) { + return vendorDao.find(vendor); + } + + @Override + public Vendor findById(Long id) { + return vendorDao.findById(id); + } + + public void add(Vendor vendor) { + vendorDao.add(vendor); + } + + public void update(Vendor vendor) { + vendorDao.update(vendor); + } + + public void delete(Long vendorId) { + vendorDao.delete(vendorId); + } +} diff --git a/src/main/resources/breadcrumb-e-c.properties b/src/main/resources/breadcrumb-e-c.properties index 4c325c2..dd3439a 100644 --- a/src/main/resources/breadcrumb-e-c.properties +++ b/src/main/resources/breadcrumb-e-c.properties @@ -4,6 +4,10 @@ update=\u4FEE\u6539 delete=\u5220\u9664 login=\u9996\u9875 role=\u89D2\u8272 -resource=\u8D44\u6E90 +resource=\u6743\u9650 user=\u7528\u6237 standard=\u89C4\u683C +agent=\u4EE3\u7406\u5546 +procurement=\u91C7\u8D2D +vendor=\u5382\u5546 +area=\u533A\u57DF diff --git a/src/main/resources/db.properties b/src/main/resources/db.properties index 8bec0a8..38d320a 100644 --- a/src/main/resources/db.properties +++ b/src/main/resources/db.properties @@ -1,4 +1,8 @@ jdbc.driver=com.mysql.jdbc.Driver -jdbc.url=jdbc:mysql://localhost:3306/vehicle +#jdbc.url=jdbc:mysql://rm-uf6ggkftngujcn480o.mysql.rds.aliyuncs.com:3306/car_sale_sh +#jdbc.password=root_123 +#jdbc.username=root + +jdbc.url=jdbc:mysql://localhost:3306/vehicle?characterEncoding=utf8&useSSL=false jdbc.password=root -jdbc.username=root +jdbc.username=root \ No newline at end of file diff --git a/src/main/resources/log4j.properties b/src/main/resources/log4j.properties index 370bc49..9a5d202 100644 --- a/src/main/resources/log4j.properties +++ b/src/main/resources/log4j.properties @@ -1,4 +1,4 @@ -log4j.rootLogger = info , stdout +log4j.rootLogger = debug , stdout ,consoleAppender ### output to the console ### log4j.appender.stdout = org.apache.log4j.ConsoleAppender @@ -6,6 +6,7 @@ log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n +log4j.appender.consoleAppender.layout.ConversionPattern=ProcessDefinitionId=%X{mdcProcessDefinitionID} executionId=%X{mdcExecutionId} mdcProcessInstanceID=%X{mdcProcessInstanceID} mdcBusinessKey=%X{mdcBusinessKey} %m%n #mybatis log4j.logger.org.apache.ibatis=info diff --git a/src/main/resources/mapper/AgentDao.xml b/src/main/resources/mapper/AgentDao.xml new file mode 100644 index 0000000..4bc35e9 --- /dev/null +++ b/src/main/resources/mapper/AgentDao.xml @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + UPDATE agent + + + openid=#{openid}, + + + level=#{level}, + + + agent_name=#{agentName}, + + + area=#{area}, + + + user_ids=#{userIdsStr}, + + + WHERE id = #{id} + + + + INSERT INTO agent(openid,level,agent_name,user_ids,area) VALUES(#{openid},#{level},#{agentName},#{userIdsStr},#{area}) + + + + DELETE FROM agent WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mapper/AreaDao.xml b/src/main/resources/mapper/AreaDao.xml new file mode 100644 index 0000000..5d1ab34 --- /dev/null +++ b/src/main/resources/mapper/AreaDao.xml @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + + + + + UPDATE area + + + area = #{area}, + + + WHERE id = #{id} + + + + INSERT INTO area(area) VALUES(#{area}) + + + + DELETE FROM area WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mapper/CarDao.xml b/src/main/resources/mapper/CarDao.xml index 30dc268..b7cec2a 100644 --- a/src/main/resources/mapper/CarDao.xml +++ b/src/main/resources/mapper/CarDao.xml @@ -19,14 +19,27 @@ + SELECT * FROM fileupload + + + + + + + + INSERT INTO fileupload(file_name,file_path,file_type,original_filename,uuid,upload_time) + VALUES(#{fileName},#{filePath},#{fileType},#{originalFilename},#{uuid},#{uploadTime}) + + + + DELETE FROM fileupload WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mapper/OrderDao.xml b/src/main/resources/mapper/OrderDao.xml new file mode 100644 index 0000000..2248e2d --- /dev/null +++ b/src/main/resources/mapper/OrderDao.xml @@ -0,0 +1,55 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + UPDATE `order` + + + openid=#{openid}, + + + WHERE id = #{id} + + + + INSERT INTO `order`(openid,car_Id,car_cnt,price,status,order_type,start_time) + VALUES(#{openid},#{carId},#{carCnt},#{price}, + #{status,typeHandler=org.apache.ibatis.type.EnumOrdinalTypeHandler}, + #{orderType,typeHandler=org.apache.ibatis.type.EnumOrdinalTypeHandler}, + now()) + + + + DELETE FROM `order` WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mapper/UserDao.xml b/src/main/resources/mapper/UserDao.xml index 5ef1aac..1600d3c 100644 --- a/src/main/resources/mapper/UserDao.xml +++ b/src/main/resources/mapper/UserDao.xml @@ -8,6 +8,7 @@ + @@ -16,6 +17,11 @@ + @@ -49,6 +58,4 @@ DELETE FROM user WHERE user_id = #{value} - - \ No newline at end of file diff --git a/src/main/resources/mapper/VendorDao.xml b/src/main/resources/mapper/VendorDao.xml new file mode 100644 index 0000000..be8c3d3 --- /dev/null +++ b/src/main/resources/mapper/VendorDao.xml @@ -0,0 +1,74 @@ + + + + + + + + + + + + + + + + + + + + + + + + + UPDATE vendor + + + vendor_name = #{vendorName}, + + + contact = #{contact}, + + + url = #{url}, + + + address = #{address}, + + + telephone = #{telephone}, + + + phone = #{phone}, + + + email = #{email}, + + + attach_id = #{attachId}, + + + WHERE id = #{id} + + + + INSERT INTO vendor(vendor_name,contact,url,address,telephone,phone,email,attach_id) + VALUES(#{vendorName},#{contact},#{url},#{address},#{telephone},#{phone},#{email},#{attachId}) + + + + DELETE FROM vendor WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mapper/procurementDao.xml b/src/main/resources/mapper/procurementDao.xml new file mode 100644 index 0000000..8d12f7b --- /dev/null +++ b/src/main/resources/mapper/procurementDao.xml @@ -0,0 +1,63 @@ + + + + + + + + + + + + + + + + + + + + + UPDATE procurement + + + procure_id=#{procureId}, + + + inventory=#{inventory}, + + + price=#{price}, + + + WHERE id = #{id} + + + + INSERT INTO procurement(procure_id,inventory,price,procure_time,create_time) VALUES(#{procureId},#{inventory},#{price},#{procureTime},now()) + + + + DELETE FROM procurement WHERE id = #{id} + + \ No newline at end of file diff --git a/src/main/resources/mybatis-config.xml b/src/main/resources/mybatis-config.xml deleted file mode 100644 index 744f726..0000000 --- a/src/main/resources/mybatis-config.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/src/main/resources/spring/mybatis-config.xml b/src/main/resources/spring/mybatis-config.xml new file mode 100644 index 0000000..fec7c5d --- /dev/null +++ b/src/main/resources/spring/mybatis-config.xml @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/main/resources/spring-mvc-shiro.xml b/src/main/resources/spring/spring-mvc-shiro.xml similarity index 98% rename from src/main/resources/spring-mvc-shiro.xml rename to src/main/resources/spring/spring-mvc-shiro.xml index 212e848..b62c891 100644 --- a/src/main/resources/spring-mvc-shiro.xml +++ b/src/main/resources/spring/spring-mvc-shiro.xml @@ -1,17 +1,17 @@ - - - - - - - - - + + + + + + + + + \ No newline at end of file diff --git a/src/main/resources/spring-mvc.xml b/src/main/resources/spring/spring-mvc.xml similarity index 69% rename from src/main/resources/spring-mvc.xml rename to src/main/resources/spring/spring-mvc.xml index 79a0001..1612b45 100644 --- a/src/main/resources/spring-mvc.xml +++ b/src/main/resources/spring/spring-mvc.xml @@ -26,13 +26,35 @@ + class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> + + + + + + + + + + + text/html;charset=UTF-8 + application/json;charset=UTF-8 + text/plain;charset=UTF-8 + + + + + @@ -46,6 +68,6 @@ - + \ No newline at end of file diff --git a/src/main/resources/spring-shiro.xml b/src/main/resources/spring/spring-shiro.xml similarity index 95% rename from src/main/resources/spring-shiro.xml rename to src/main/resources/spring/spring-shiro.xml index 9a4fe14..fde8ca3 100644 --- a/src/main/resources/spring-shiro.xml +++ b/src/main/resources/spring/spring-shiro.xml @@ -56,13 +56,15 @@ + /**/external/** = anon /**/import = anon /login.jsp = anon - /logout = logout /dist/** = anon /img/** = anon + /css/** = anon /js/** = anon /bower_components/** = anon + /logout = logout /** = authc diff --git a/src/main/resources/spring.xml b/src/main/resources/spring/spring.xml similarity index 93% rename from src/main/resources/spring.xml rename to src/main/resources/spring/spring.xml index 57c4cb5..46ff119 100644 --- a/src/main/resources/spring.xml +++ b/src/main/resources/spring/spring.xml @@ -42,7 +42,7 @@ - + @@ -67,5 +67,5 @@ - + \ No newline at end of file diff --git a/src/main/resources/upload.properties b/src/main/resources/upload.properties new file mode 100644 index 0000000..0c05479 --- /dev/null +++ b/src/main/resources/upload.properties @@ -0,0 +1,9 @@ +allowFileTypes=.TXT,.DOC,.DOCX,.XLS,.XLSX,.PDF,.GIF,.PNG,.JPG,.JPEG,.BMP +allowImageTypes=.GIF,.PNG,.JPG,.JPEG,.BMP +allowAnnexTypes=.TXT,.DOC,.DOCX,.XLS,.XLSX,.PDF,.GIF,.PNG,.JPG,.JPEG,.BMP +ftp.ip=114.55.150.82 +ftp.root=0 +ftp.username=ftpadmin +ftp.password=ftpadmin + +ftp.readurl=ftp\://114.55.150.82/ \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/tld/spring-form.tld b/src/main/webapp/WEB-INF/tld/spring-form.tld new file mode 100644 index 0000000..a6c39cc --- /dev/null +++ b/src/main/webapp/WEB-INF/tld/spring-form.tld @@ -0,0 +1,2469 @@ + + + + Spring Framework JSP Form Tag Library + 4.3 + form + http://www.springframework.org/tags/form + + + Renders an HTML 'form' tag and exposes a binding path to inner tags + for binding. + form + org.springframework.web.servlet.tags.form.FormTag + JSP + + HTML Standard Attribute + id + false + true + + + HTML Standard Attribute - added for backwards compatibility cases + name + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + Name of the model attribute under which the form object is exposed. + Defaults to 'command'. + modelAttribute + false + true + + + DEPRECATED: Use "modelAttribute" instead. + commandName + false + true + + + HTML Required Attribute + action + false + true + + + Action reference to be appended to the current servlet path + servletRelativeAction + false + true + + + HTML Optional Attribute + method + false + true + + + HTML Optional Attribute + target + false + true + + + HTML Optional Attribute + enctype + false + true + + + Specifies the list of character encodings for input data that is accepted + by the server processing this form. The value is a space- and/or comma-delimited list of + charset values. The client must interpret this list as an exclusive-or list, i.e. the + server is able to accept any single character encoding per entity received. + acceptCharset + false + true + + + HTML Event Attribute + onsubmit + false + true + + + HTML Event Attribute + onreset + false + true + + + Common Optional Attribute + autocomplete + false + true + + + The parameter name used for HTTP methods other then GET and POST. + Default is '_method'. + methodParam + false + true + + true + + + + Renders an HTML 'input' tag with type 'text' using the bound value. + input + org.springframework.web.servlet.tags.form.InputTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + HTML Optional Attribute + size + false + true + + + HTML Optional Attribute + maxlength + false + true + + + HTML Optional Attribute + alt + false + true + + + HTML Event Attribute + onselect + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will make the HTML element readonly. + readonly + false + true + + + Common Optional Attribute + autocomplete + false + true + + true + + + + Renders an HTML 'input' tag with type 'password' using the bound value. + password + org.springframework.web.servlet.tags.form.PasswordInputTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + HTML Optional Attribute + size + false + true + + + HTML Optional Attribute + maxlength + false + true + + + HTML Optional Attribute + alt + false + true + + + HTML Event Attribute + onselect + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will make the HTML element readonly. + readonly + false + true + + + Common Optional Attribute + autocomplete + false + true + + + Is the password value to be shown? Defaults to false. + showPassword + false + true + + true + + + + Renders an HTML 'input' tag with type 'hidden' using the bound value. + hidden + org.springframework.web.servlet.tags.form.HiddenInputTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + true + + + + Renders an HTML 'select' element. Supports data binding to the + selected option. + select + org.springframework.web.servlet.tags.form.SelectTag + JSP + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + The Collection, Map or array of objects used to generate the + inner 'option' tags + items + false + true + + + Name of the property mapped to 'value' attribute of the + 'option' tag + itemValue + false + true + + + Name of the property mapped to the inner text of the + 'option' tag + itemLabel + false + true + + + HTML Optional Attribute + size + false + true + + + HTML Optional Attribute + multiple + false + true + + true + + + + Renders a single HTML 'option'. + Sets 'selected' as appropriate based on bound value. + option + org.springframework.web.servlet.tags.form.OptionTag + JSP + + The actual value bound to the 'value' attribute + value + java.lang.Object + + + The String representation of thr value bound to the 'value' + attribute, taking into consideration any PropertyEditor associated with + the enclosing 'select' tag. + displayValue + java.lang.String + + + HTML Standard Attribute + id + false + true + + + HTML Optional Attribute + value + true + true + + + HTML Optional Attribute + label + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + true + + + + Renders a list of HTML 'option' tags. Sets 'selected' as appropriate + based on bound value. + options + org.springframework.web.servlet.tags.form.OptionsTag + empty + + HTML Standard Attribute + id + false + true + + + The Collection, Map or array of objects used to generate the inner + 'option' tags. This attribute is required unless the containing select's property + for data binding is an Enum, in which case the enum's values are used. + items + false + true + + + Name of the property mapped to 'value' attribute of the 'option' tag + itemValue + false + true + + + Name of the property mapped to the inner text of the 'option' tag + itemLabel + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + true + + + + Renders an HTML 'input' tag with type 'radio'. + radiobutton + org.springframework.web.servlet.tags.form.RadioButtonTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + HTML Optional Attribute + value + false + true + + + Value to be displayed as part of the tag + label + false + true + + true + + + + Renders multiple HTML 'input' tags with type 'radio'. + radiobuttons + org.springframework.web.servlet.tags.form.RadioButtonsTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + The Collection, Map or array of objects used to generate the 'input' + tags with type 'radio'. This attribute is required unless the property for data + binding is an Enum, in which case the enum's values are used. + items + false + true + + + Name of the property mapped to 'value' attribute of the 'input' + tags with type 'radio' + itemValue + false + true + + + Value to be displayed as part of the 'input' tags with type + 'radio' + itemLabel + false + true + + + Delimiter to use between each 'input' tag with type 'radio'. + There is no delimiter by default. + delimiter + false + true + + + Specifies the HTML element that is used to enclose each 'input' + tag with type 'radio'. Defaults to 'span'. + element + false + true + + true + + + + Renders an HTML 'input' tag with type 'checkbox'. + checkbox + org.springframework.web.servlet.tags.form.CheckboxTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + HTML Optional Attribute + value + false + true + + + Value to be displayed as part of the tag + label + false + true + + true + + + + Renders multiple HTML 'input' tags with type 'checkbox'. + checkboxes + org.springframework.web.servlet.tags.form.CheckboxesTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + The Collection, Map or array of objects used to generate the + 'input' tags with type 'checkbox' + items + true + true + + + Name of the property mapped to 'value' attribute of the 'input' + tags with type 'checkbox' + itemValue + false + true + + + Value to be displayed as part of the 'input' tags with type + 'checkbox' + itemLabel + false + true + + + Delimiter to use between each 'input' tag with type 'checkbox'. + There is no delimiter by default. + delimiter + false + true + + + Specifies the HTML element that is used to enclose each 'input' + tag with type 'checkbox'. Defaults to 'span'. + element + false + true + + true + + + + Renders an HTML 'textarea'. + textarea + org.springframework.web.servlet.tags.form.TextareaTag + empty + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used when the bound field has errors. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + HTML Event Attribute + onfocus + false + true + + + HTML Event Attribute + onblur + false + true + + + HTML Event Attribute + onchange + false + true + + + HTML Standard Attribute + accesskey + false + true + + + HTML Required Attribute + rows + false + true + + + HTML Required Attribute + cols + false + true + + + HTML Event Attribute + onselect + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will make the HTML element readonly. + readonly + false + true + + true + + + + Renders field errors in an HTML 'span' tag. + errors + org.springframework.web.servlet.tags.form.ErrorsTag + JSP + + messages + java.util.List + + + Path to errors object for data binding + path + false + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + Delimiter for displaying multiple error messages. + Defaults to the HTML br tag. + delimiter + false + true + + + Equivalent to "class" - HTML Optional Attribute + cssClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + + Specifies the HTML element that is used to render the enclosing errors. + element + false + true + + true + + + + Renders a form field label in an HTML 'label' tag. + label + org.springframework.web.servlet.tags.form.LabelTag + JSP + + Path to property for data binding + path + true + true + + + HTML Standard Attribute + id + false + true + + + Enable/disable HTML escaping of rendered values. + htmlEscape + false + true + + + HTML Standard Attribute + for + false + true + + + Equivalent to "class" - HTML Optional Attribute. + cssClass + false + true + + + Equivalent to "class" - HTML Optional Attribute. + Used only when errors are present. + cssErrorClass + false + true + + + Equivalent to "style" - HTML Optional Attribute + cssStyle + false + true + + + HTML Standard Attribute + lang + false + true + + + HTML Standard Attribute + title + false + true + + + HTML Standard Attribute + dir + false + true + + + HTML Standard Attribute + tabindex + false + true + + + HTML Event Attribute + onclick + false + true + + + HTML Event Attribute + ondblclick + false + true + + + HTML Event Attribute + onmousedown + false + true + + + HTML Event Attribute + onmouseup + false + true + + + HTML Event Attribute + onmouseover + false + true + + + HTML Event Attribute + onmousemove + false + true + + + HTML Event Attribute + onmouseout + false + true + + + HTML Event Attribute + onkeypress + false + true + + + HTML Event Attribute + onkeyup + false + true + + + HTML Event Attribute + onkeydown + false + true + + true + + + + Renders an HTML 'button' tag. + button + org.springframework.web.servlet.tags.form.ButtonTag + JSP + + HTML Standard Attribute + id + false + true + + + The name attribute for the HTML button tag + name + false + true + + + The value attribute for the HTML button tag + value + false + true + + + HTML Optional Attribute. Setting the value of this attribute to 'true' + will disable the HTML element. + disabled + false + true + + true + + + diff --git a/src/main/webapp/WEB-INF/tld/spring.tld b/src/main/webapp/WEB-INF/tld/spring.tld new file mode 100644 index 0000000..8c6a8ca --- /dev/null +++ b/src/main/webapp/WEB-INF/tld/spring.tld @@ -0,0 +1,467 @@ + + + + Spring Framework JSP Tag Library + 4.0 + spring + http://www.springframework.org/tags + + + Sets default HTML escape value for the current page. + Overrides a "defaultHtmlEscape" context-param in web.xml, if any. + htmlEscape + org.springframework.web.servlet.tags.HtmlEscapeTag + JSP + + Set the default value for HTML escaping, to be put + into the current PageContext. + defaultHtmlEscape + true + true + + + + + Escapes its enclosed body content, applying HTML escaping and/or JavaScript + escaping. The HTML escaping flag participates in a page-wide or application-wide setting + (i.e. by HtmlEscapeTag or a "defaultHtmlEscape" context-param in web.xml). + escapeBody + org.springframework.web.servlet.tags.EscapeBodyTag + JSP + + Set HTML escaping for this tag, as boolean value. Overrides the + default HTML escaping setting for the current page. + htmlEscape + false + true + + + Set JavaScript escaping for this tag, as boolean value. + Default is 'false'. + javaScriptEscape + false + true + + + + + Retrieves the message with the given code, or text if code isn't resolvable. + The HTML escaping flag participates in a page-wide or application-wide setting + (i.e. by HtmlEscapeTag or a "defaultHtmlEscape" context-param in web.xml). + message + org.springframework.web.servlet.tags.MessageTag + JSP + + A MessageSourceResolvable argument (direct or through JSP EL). + Fits nicely when used in conjunction with Spring's own validation error classes + which all implement the MessageSourceResolvable interface. For example, this + allows you to iterate over all of the errors in a form, passing each error + (using a runtime expression) as the value of this 'message' attribute, thus + effecting the easy display of such error messages. + message + false + true + + + The code (key) to use when looking up the message. + If code is not provided, the text attribute will be used. + code + false + true + + + Set optional message arguments for this tag, as a (comma-) + delimited String (each String argument can contain JSP EL), an Object array + (used as argument array), or a single Object (used as single argument). + You can additionally use nested spring:argument tags. + arguments + false + true + + + The separator character to be used for splitting the + arguments string value; defaults to a 'comma' (','). + argumentSeparator + false + true + + + Default text to output when a message for the given code + could not be found. If both text and code are not set, the tag will + output null. + text + false + true + + + The string to use when binding the result to the page, + request, session or application scope. If not specified, the result + gets outputted to the writer (i.e. typically directly to the JSP). + var + false + true + + + The scope to use when exporting the result to a variable. + This attribute is only used when var is also set. Possible values are + page, request, session and application. + scope + false + true + + + Set HTML escaping for this tag, as boolean value. + Overrides the default HTML escaping setting for the current page. + htmlEscape + false + true + + + Set JavaScript escaping for this tag, as boolean value. + Default is 'false'. + javaScriptEscape + false + true + + + + + Retrieves the theme message with the given code, or text if code isn't + resolvable. The HTML escaping flag participates in a page-wide or application-wide setting + (i.e. by HtmlEscapeTag or a "defaultHtmlEscape" context-param in web.xml). + theme + org.springframework.web.servlet.tags.ThemeTag + JSP + + A MessageSourceResolvable argument (direct or through JSP EL). + message + false + true + + + The code (key) to use when looking up the message. + If code is not provided, the text attribute will be used. + code + false + true + + + Set optional message arguments for this tag, as a (comma-) + delimited String (each String argument can contain JSP EL), an Object array + (used as argument array), or a single Object (used as single argument). + You can additionally use nested spring:argument tags. + arguments + false + true + + + The separator character to be used for splitting the + arguments string value; defaults to a 'comma' (','). + argumentSeparator + false + true + + + Default text to output when a message for the given code + could not be found. If both text and code are not set, the tag will + output null. + text + false + true + + + The string to use when binding the result to the page, + request, session or application scope. If not specified, the result + gets outputted to the writer (i.e. typically directly to the JSP). + var + false + true + + + The scope to use when exporting the result to a variable. + This attribute is only used when var is also set. Possible values are + page, request, session and application. + scope + false + true + + + Set HTML escaping for this tag, as boolean value. + Overrides the default HTML escaping setting for the current page. + htmlEscape + false + true + + + Set JavaScript escaping for this tag, as boolean value. + Default is 'false'. + javaScriptEscape + false + true + + + + + Argument tag based on the JSTL fmt:param tag. The purpose is to + support arguments inside the spring:message and spring:theme tags. + argument + org.springframework.web.servlet.tags.ArgumentTag + JSP + + The value of the argument. + value + false + true + java.lang.Object + + + + + Provides Errors instance in case of bind errors. The HTML escaping + flag participates in a page-wide or application-wide setting (i.e. by HtmlEscapeTag + or a "defaultHtmlEscape" context-param in web.xml). + hasBindErrors + org.springframework.web.servlet.tags.BindErrorsTag + JSP + + errors + org.springframework.validation.Errors + + + The name of the bean in the request, that needs to be + inspected for errors. If errors are available for this bean, they + will be bound under the 'errors' key. + name + true + true + + + Set HTML escaping for this tag, as boolean value. + Overrides the default HTML escaping setting for the current page. + htmlEscape + false + true + + + + + Sets a nested path to be used by the bind tag's path. + nestedPath + org.springframework.web.servlet.tags.NestedPathTag + JSP + + nestedPath + java.lang.String + + + Set the path that this tag should apply. E.g. 'customer' + to allow bind paths like 'address.street' rather than + 'customer.address.street'. + path + true + true + + + + + Provides BindStatus object for the given bind path. The HTML escaping + flag participates in a page-wide or application-wide setting (i.e. by HtmlEscapeTag + or a "defaultHtmlEscape" context-param in web.xml). + bind + org.springframework.web.servlet.tags.BindTag + JSP + + status + org.springframework.web.servlet.support.BindStatus + + + The path to the bean or bean property to bind status + information for. For instance account.name, company.address.zipCode + or just employee. The status object will exported to the page scope, + specifically for this bean or bean property. + path + true + true + + + Set whether to ignore a nested path, if any. + Default is to not ignore. + ignoreNestedPath + false + true + + + Set HTML escaping for this tag, as boolean value. Overrides + the default HTML escaping setting for the current page. + htmlEscape + false + true + + + + + Provides transformation of variables to Strings, using an appropriate + custom PropertyEditor from BindTag (can only be used inside BindTag). The HTML + escaping flag participates in a page-wide or application-wide setting (i.e. by + HtmlEscapeTag or a 'defaultHtmlEscape' context-param in web.xml). + transform + org.springframework.web.servlet.tags.TransformTag + JSP + + The value to transform. This is the actual object you want + to have transformed (for instance a Date). Using the PropertyEditor that + is currently in use by the 'spring:bind' tag. + value + true + true + + + The string to use when binding the result to the page, + request, session or application scope. If not specified, the result gets + outputted to the writer (i.e. typically directly to the JSP). + var + false + true + + + The scope to use when exported the result to a variable. + This attribute is only used when var is also set. Possible values are + page, request, session and application. + scope + false + true + + + Set HTML escaping for this tag, as boolean value. Overrides + the default HTML escaping setting for the current page. + htmlEscape + false + true + + + + + URL tag based on the JSTL c:url tag. This variant is fully + backwards compatible with the standard tag. Enhancements include support + for URL template parameters. + url + org.springframework.web.servlet.tags.UrlTag + JSP + + The URL to build. This value can include template place holders + that are replaced with the URL encoded value of the named parameter. Parameters + must be defined using the param tag inside the body of this tag. + value + true + true + + + Specifies a remote application context path. The default is the + current application context path. + context + false + true + + + The name of the variable to export the URL value to. + var + false + true + + + The scope for the var. 'application', 'session', 'request' and + 'page' scopes are supported. Defaults to page scope. This attribute has no + effect unless the var attribute is also defined. + scope + false + true + + + Set HTML escaping for this tag, as a boolean value. Overrides the + default HTML escaping setting for the current page. + htmlEscape + false + true + + + Set JavaScript escaping for this tag, as a boolean value. + Default is 'false'. + javaScriptEscape + false + true + + + + + Parameter tag based on the JSTL c:param tag. The sole purpose is to + support params inside the spring:url tag. + param + org.springframework.web.servlet.tags.ParamTag + JSP + + The name of the parameter. + name + true + true + + + The value of the parameter. + value + false + true + + + + + Evaluates a Spring expression (SpEL) and either prints the result + or assigns it to a variable. + eval + org.springframework.web.servlet.tags.EvalTag + JSP + + The expression to evaluate. + expression + true + true + + + The name of the variable to export the evaluation result to. + var + false + true + + + The scope for the var. 'application', 'session', 'request' and + 'page' scopes are supported. Defaults to page scope. This attribute has no + effect unless the var attribute is also defined. + scope + false + true + + + Set HTML escaping for this tag, as a boolean value. Overrides the + default HTML escaping setting for the current page. + htmlEscape + false + true + + + Set JavaScript escaping for this tag, as a boolean value. + Default is 'false'. + javaScriptEscape + false + true + + + + + Helps to prepare a URL to a Spring MVC controller method. + mvcUrl + org.springframework.web.servlet.mvc.method.annotation.MvcUriComponentsBuilder + org.springframework.web.servlet.mvc.method.annotation.MvcUriComponentsBuilder.MethodArgumentBuilder fromMappingName(java.lang.String) + + + diff --git a/src/main/webapp/WEB-INF/view/admin/batchUpload.jsp b/src/main/webapp/WEB-INF/view/admin/batchUpload.jsp new file mode 100644 index 0000000..b7227ec --- /dev/null +++ b/src/main/webapp/WEB-INF/view/admin/batchUpload.jsp @@ -0,0 +1,32 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> + +

\ No newline at end of file diff --git a/src/main/webapp/WEB-INF/view/admin/bottom.jsp b/src/main/webapp/WEB-INF/view/admin/bottom.jsp index 954c032..bc74a8a 100644 --- a/src/main/webapp/WEB-INF/view/admin/bottom.jsp +++ b/src/main/webapp/WEB-INF/view/admin/bottom.jsp @@ -11,17 +11,20 @@ - + + + + diff --git a/src/main/webapp/breadcrumb.jsp b/src/main/webapp/WEB-INF/view/admin/breadcrumb.jsp similarity index 100% rename from src/main/webapp/breadcrumb.jsp rename to src/main/webapp/WEB-INF/view/admin/breadcrumb.jsp diff --git a/src/main/webapp/WEB-INF/view/admin/main.jsp b/src/main/webapp/WEB-INF/view/admin/main.jsp index a21c6de..fc34ce2 100644 --- a/src/main/webapp/WEB-INF/view/admin/main.jsp +++ b/src/main/webapp/WEB-INF/view/admin/main.jsp @@ -1,5 +1,7 @@ <%@ page contentType="text/html;charset=UTF-8" language="java"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> + +
@@ -109,3 +111,4 @@
+ diff --git a/src/main/webapp/WEB-INF/view/admin/nav.jsp b/src/main/webapp/WEB-INF/view/admin/nav.jsp index f609c1f..b6979b2 100644 --- a/src/main/webapp/WEB-INF/view/admin/nav.jsp +++ b/src/main/webapp/WEB-INF/view/admin/nav.jsp @@ -34,25 +34,20 @@ - + + + + + - - - -
- \ No newline at end of file + + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/view/admin/pageSplit.jsp b/src/main/webapp/WEB-INF/view/admin/pageSplit.jsp new file mode 100644 index 0000000..690c0d7 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/admin/pageSplit.jsp @@ -0,0 +1,40 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java"%> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> + + + diff --git a/src/main/webapp/WEB-INF/view/admin/system/resource/resource.jsp b/src/main/webapp/WEB-INF/view/admin/system/resource/resource.jsp index 057310b..afad3c5 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/resource/resource.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/resource/resource.jsp @@ -5,7 +5,7 @@
- +

权限管理

@@ -20,6 +20,12 @@
+
+
+
+ 新增 +
+
@@ -34,6 +40,7 @@ @@ -41,9 +48,8 @@
${resource.name} ${resource.permission} + 修改 删除
- 添加权限 -
+ +
diff --git a/src/main/webapp/WEB-INF/view/admin/system/resource/resource_add.jsp b/src/main/webapp/WEB-INF/view/admin/system/resource/resource_add.jsp index a5dd721..a9bbc00 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/resource/resource_add.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/resource/resource_add.jsp @@ -5,7 +5,7 @@
- +

权限管理

diff --git a/src/main/webapp/WEB-INF/view/admin/system/resource/resource_update.jsp b/src/main/webapp/WEB-INF/view/admin/system/resource/resource_update.jsp new file mode 100644 index 0000000..22784c3 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/admin/system/resource/resource_update.jsp @@ -0,0 +1,51 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + + + +
+
+ +
+

权限管理

+
+
+
+
+
+
+
+ 权限信息 +
+ +
+
+
+ + + + + + + + +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + + diff --git a/src/main/webapp/WEB-INF/view/admin/system/role/role.jsp b/src/main/webapp/WEB-INF/view/admin/system/role/role.jsp index 1d12769..b5a0a2b 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/role/role.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/role/role.jsp @@ -1,11 +1,10 @@ <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> -<%----%>
- +

角色管理

@@ -20,6 +19,13 @@
+
+
+
+ 新增 +
+
@@ -44,10 +50,10 @@
- 添加角色 -
+ + +
diff --git a/src/main/webapp/WEB-INF/view/admin/system/role/role_add.jsp b/src/main/webapp/WEB-INF/view/admin/system/role/role_add.jsp index 8624eba..e4de033 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/role/role_add.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/role/role_add.jsp @@ -5,7 +5,7 @@
- +

用户管理

diff --git a/src/main/webapp/WEB-INF/view/admin/system/role/role_update.jsp b/src/main/webapp/WEB-INF/view/admin/system/role/role_update.jsp index 8606bc9..546f80b 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/role/role_update.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/role/role_update.jsp @@ -6,7 +6,7 @@
- +

角色管理

diff --git a/src/main/webapp/WEB-INF/view/admin/system/user/user.jsp b/src/main/webapp/WEB-INF/view/admin/system/user/user.jsp index 119618e..1c7c440 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/user/user.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/user/user.jsp @@ -5,7 +5,7 @@
- +

用户管理

@@ -20,9 +20,17 @@
+
+
+
+ 新增 +
+
+ @@ -33,8 +41,9 @@ + - +
登录名 用户名 密码 权限
${user.userId}${user.username} ${user.password}${user.roleIdsStr}${user.roleDesc} 修改  
- 添加用户 + +
diff --git a/src/main/webapp/WEB-INF/view/admin/system/user/user_add.jsp b/src/main/webapp/WEB-INF/view/admin/system/user/user_add.jsp index a15acd6..81d482c 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/user/user_add.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/user/user_add.jsp @@ -5,7 +5,7 @@
- +

用户管理

@@ -21,8 +21,10 @@
- + + + diff --git a/src/main/webapp/WEB-INF/view/admin/system/user/user_update.jsp b/src/main/webapp/WEB-INF/view/admin/system/user/user_update.jsp index b4d0105..ca42f70 100644 --- a/src/main/webapp/WEB-INF/view/admin/system/user/user_update.jsp +++ b/src/main/webapp/WEB-INF/view/admin/system/user/user_update.jsp @@ -6,7 +6,7 @@
- +

用户管理

@@ -22,9 +22,10 @@
- + -

+ + diff --git a/src/main/webapp/WEB-INF/view/vm/agent/agent.jsp b/src/main/webapp/WEB-INF/view/vm/agent/agent.jsp new file mode 100644 index 0000000..a1d8105 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/agent/agent.jsp @@ -0,0 +1,106 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> + + +
+
+ +
+
+
+
+
+
+ 代理商信息 +
+ +
+
+ + +
+ +
+
+ 新增 + +
+ + +
+ + + + + + + + + + + + + + + + + + + + + + + +
级别名称绑定职员区域openid操作
${agent.level.getName()}${agent.agentName}${agent.usernames}${agent.area}${agent.openid} + 修改 + 删除 +
+ +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + diff --git a/src/main/webapp/WEB-INF/view/vm/agent/agent_add.jsp b/src/main/webapp/WEB-INF/view/vm/agent/agent_add.jsp new file mode 100644 index 0000000..57b6332 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/agent/agent_add.jsp @@ -0,0 +1,76 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

代理商管理

+
+
+
+
+
+
+
+ 代理商管理 +
+ +
+
+ +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/agent/agent_update.jsp b/src/main/webapp/WEB-INF/view/vm/agent/agent_update.jsp new file mode 100644 index 0000000..56ecf16 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/agent/agent_update.jsp @@ -0,0 +1,77 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

代理商管理

+
+
+
+
+
+
+
+ 代理商管理 +
+ +
+
+ + +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/area/area.jsp b/src/main/webapp/WEB-INF/view/vm/area/area.jsp new file mode 100644 index 0000000..2e9605b --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/area/area.jsp @@ -0,0 +1,82 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> + + +
+
+ +
+
+
+
+
+
+ 区域信息 +
+ +
+
+ + +
+ +
+ + + +
+ + + + + + + + + + + + + + + +
区域操作
${area.area} + 修改 + 删除 +
+ +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + diff --git a/src/main/webapp/WEB-INF/view/vm/area/area_add.jsp b/src/main/webapp/WEB-INF/view/vm/area/area_add.jsp new file mode 100644 index 0000000..9bdae1b --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/area/area_add.jsp @@ -0,0 +1,47 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

区域管理

+
+
+
+
+
+
+
+ 区域管理 +
+ +
+
+ +
+ +
+ +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/area/area_update.jsp b/src/main/webapp/WEB-INF/view/vm/area/area_update.jsp new file mode 100644 index 0000000..9277654 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/area/area_update.jsp @@ -0,0 +1,48 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

区域管理

+
+
+
+
+
+
+
+ 区域管理 +
+ +
+
+ + +
+ +
+ +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/car/car.jsp b/src/main/webapp/WEB-INF/view/vm/car/car.jsp index 6b009d9..7ecd3c2 100644 --- a/src/main/webapp/WEB-INF/view/vm/car/car.jsp +++ b/src/main/webapp/WEB-INF/view/vm/car/car.jsp @@ -1,13 +1,11 @@ <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
- -
-

车辆管理

-
+
@@ -19,36 +17,61 @@
- <%-- -
查询条件
+ + +
+
- +
+ 新增 + +
+ + +
- --%> @@ -84,7 +107,9 @@
- 添加车辆 + +
+
diff --git a/src/main/webapp/WEB-INF/view/vm/car/car_add.jsp b/src/main/webapp/WEB-INF/view/vm/car/car_add.jsp index b4b6724..40e2f4b 100644 --- a/src/main/webapp/WEB-INF/view/vm/car/car_add.jsp +++ b/src/main/webapp/WEB-INF/view/vm/car/car_add.jsp @@ -4,7 +4,7 @@
- +

车辆管理

diff --git a/src/main/webapp/WEB-INF/view/vm/car/car_update.jsp b/src/main/webapp/WEB-INF/view/vm/car/car_update.jsp index 40da84f..3beaf10 100644 --- a/src/main/webapp/WEB-INF/view/vm/car/car_update.jsp +++ b/src/main/webapp/WEB-INF/view/vm/car/car_update.jsp @@ -5,7 +5,7 @@
- +

车辆管理

diff --git a/src/main/webapp/WEB-INF/view/vm/order/external_order_add.jsp b/src/main/webapp/WEB-INF/view/vm/order/external_order_add.jsp new file mode 100644 index 0000000..40da619 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/order/external_order_add.jsp @@ -0,0 +1,64 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + + + + + 代理商订单 + + + + + + + + +
+

订单申请

+ +
+ + +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+
+ +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/view/vm/order/external_order_add_success.jsp b/src/main/webapp/WEB-INF/view/vm/order/external_order_add_success.jsp new file mode 100644 index 0000000..70be05b --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/order/external_order_add_success.jsp @@ -0,0 +1,32 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + + + + + 代理商订单 + + + + + + + + +
+

订单申请成功

+
+ + + + + + + + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/view/vm/order/order.jsp b/src/main/webapp/WEB-INF/view/vm/order/order.jsp new file mode 100644 index 0000000..1b19b6a --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/order/order.jsp @@ -0,0 +1,102 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> + + +
+
+ +
+
+
+
+
+
+ 代理商信息 +
+ +
+
+ + +
+ +
+
+ 新增 + +
+ + +
+ + + + + + + + + + + + + + + + + + + + + +
级别名称绑定职员区域操作
${agent.level.getName()}${agent.agentName}${agent.usernames}${agent.area} + 修改 + 删除 +
+ +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + diff --git a/src/main/webapp/WEB-INF/view/vm/order/order_update.jsp b/src/main/webapp/WEB-INF/view/vm/order/order_update.jsp new file mode 100644 index 0000000..f1715fe --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/order/order_update.jsp @@ -0,0 +1,71 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

代理商管理

+
+
+
+
+
+
+
+ 代理商管理 +
+ +
+
+ + +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/procurement/procurement.jsp b/src/main/webapp/WEB-INF/view/vm/procurement/procurement.jsp new file mode 100644 index 0000000..b338241 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/procurement/procurement.jsp @@ -0,0 +1,111 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + + +
+
+ +
+
+
+
+
+
+ 采购管理 +
+ +
+
+
+ +
+ +
+
+ 新增 +
+ + + +
+ + + + + + + + + + + + + + + + + + + + + +
采购单编号采购时间采购量采购价格操作
${procurement.procureId}${procurement.procureTime}${procurement.inventory}${procurement.price} + 修改 + 删除 +
+ +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + diff --git a/src/main/webapp/WEB-INF/view/vm/procurement/procurement_add.jsp b/src/main/webapp/WEB-INF/view/vm/procurement/procurement_add.jsp new file mode 100644 index 0000000..8da3f8d --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/procurement/procurement_add.jsp @@ -0,0 +1,67 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> + + +
+
+ +
+

采购管理

+
+
+
+
+
+
+
+ 采购管理 +
+ +
+
+
+
+ +
+ + + +
+
+
+ +
+ +
+ +
+ +
+ +
+ +
+
+
+ +
+ + +
+
+ +
+ +
+ +
+ +
+
+ + +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/procurement/procurement_update.jsp b/src/main/webapp/WEB-INF/view/vm/procurement/procurement_update.jsp new file mode 100644 index 0000000..ccbcb41 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/procurement/procurement_update.jsp @@ -0,0 +1,65 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> + + + +
+
+ +
+

采购管理

+
+
+
+
+
+
+
+ 采购管理 +
+ +
+
+
+ +
+ +
+ +
+
+
+ +
+ +
+ +
+ +
+ +
+ + +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ + +
+ diff --git a/src/main/webapp/WEB-INF/view/vm/standard/standard.jsp b/src/main/webapp/WEB-INF/view/vm/standard/standard.jsp index b2ab6a2..a9ac030 100644 --- a/src/main/webapp/WEB-INF/view/vm/standard/standard.jsp +++ b/src/main/webapp/WEB-INF/view/vm/standard/standard.jsp @@ -1,10 +1,11 @@ <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
- +

规格管理

@@ -19,6 +20,31 @@
+ + +
+ +
+ + + +
@@ -39,7 +65,8 @@
- 添加规格 + +
diff --git a/src/main/webapp/WEB-INF/view/vm/standard/standard_add.jsp b/src/main/webapp/WEB-INF/view/vm/standard/standard_add.jsp index 718a644..b31ff16 100644 --- a/src/main/webapp/WEB-INF/view/vm/standard/standard_add.jsp +++ b/src/main/webapp/WEB-INF/view/vm/standard/standard_add.jsp @@ -4,7 +4,7 @@
- +

规格管理

diff --git a/src/main/webapp/WEB-INF/view/vm/standard/standard_update.jsp b/src/main/webapp/WEB-INF/view/vm/standard/standard_update.jsp index 64fc513..0d3189f 100644 --- a/src/main/webapp/WEB-INF/view/vm/standard/standard_update.jsp +++ b/src/main/webapp/WEB-INF/view/vm/standard/standard_update.jsp @@ -5,7 +5,7 @@
- +

规格管理

diff --git a/src/main/webapp/WEB-INF/view/vm/vendor/vendor.jsp b/src/main/webapp/WEB-INF/view/vm/vendor/vendor.jsp new file mode 100644 index 0000000..8233de5 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/vendor/vendor.jsp @@ -0,0 +1,102 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> + + +
+
+ +
+
+
+
+
+
+ 厂商信息 +
+ +
+
+ + +
+ +
+ + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
厂商负责人网站地址电话手机邮箱操作
${vendor.vendorName}${vendor.contact}点击跳转 + ${vendor.address}${vendor.telephone}${vendor.phone}${vendor.email} + 修改 + 删除 +
+ +
+
+ +
+ +
+ +
+ +
+
+ + +
+ + + diff --git a/src/main/webapp/WEB-INF/view/vm/vendor/vendor_add.jsp b/src/main/webapp/WEB-INF/view/vm/vendor/vendor_add.jsp new file mode 100644 index 0000000..3a1d168 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/vendor/vendor_add.jsp @@ -0,0 +1,98 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

厂商管理

+
+
+
+
+
+
+
+ 厂商管理 +
+ +
+
+ +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ + +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ + + \ No newline at end of file diff --git a/src/main/webapp/WEB-INF/view/vm/vendor/vendor_update.jsp b/src/main/webapp/WEB-INF/view/vm/vendor/vendor_update.jsp new file mode 100644 index 0000000..e496d78 --- /dev/null +++ b/src/main/webapp/WEB-INF/view/vm/vendor/vendor_update.jsp @@ -0,0 +1,99 @@ +<%@ page contentType="text/html;charset=UTF-8" language="java" %> +<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %> +<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form" %> + + +
+
+ +
+

厂商管理

+
+
+
+
+
+
+
+ 厂商管理 +
+ +
+
+ + +
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ + +
+
+ + +
+
+ +
+ +
+ +
+ +
+
+ +
+ + + diff --git a/src/main/webapp/WEB-INF/web.xml b/src/main/webapp/WEB-INF/web.xml index 7844f93..0bdc465 100644 --- a/src/main/webapp/WEB-INF/web.xml +++ b/src/main/webapp/WEB-INF/web.xml @@ -11,7 +11,7 @@ contextConfigLocation - classpath:spring.xml + classpath:spring/spring.xml org.springframework.web.util.Log4jConfigListener @@ -25,6 +25,10 @@ default *.jpg + + default + *.xlsx + default *.lang @@ -37,6 +41,18 @@ default *.woff + + default + *.ttf + + + default + *.svg + + + default + *.eot + default *.woff2 @@ -49,6 +65,10 @@ default *.css + + default + *.less + default *.html @@ -65,11 +85,18 @@ default *.gif - - default - *.ttf - - + + + + + http://www.springframework.org/tags/form + tld/spring-form.tld + + + http://www.springframework.org/tags + tld/spring.tld + + @@ -108,7 +135,7 @@ org.springframework.web.servlet.DispatcherServlet contextConfigLocation - classpath:spring-mvc.xml + classpath:spring/spring-mvc.xml 1 diff --git a/src/main/webapp/bower_components/bootstrap/less/mixins/grid-framework.less b/src/main/webapp/bower_components/bootstrap/less/mixins/grid-framework.less index 8c23eed..f2a6925 100644 --- a/src/main/webapp/bower_components/bootstrap/less/mixins/grid-framework.less +++ b/src/main/webapp/bower_components/bootstrap/less/mixins/grid-framework.less @@ -45,7 +45,7 @@ .calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) { .col-@{class}-@{index} { - width: percentage((@index / @grid-columns)); + width: percentage((@index / @grid-columns))+1; } } .calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) { diff --git a/src/main/webapp/bower_components/sweetalert/sweetalert-dev.js b/src/main/webapp/bower_components/sweetalert/sweetalert-dev.js new file mode 100644 index 0000000..9198f2f --- /dev/null +++ b/src/main/webapp/bower_components/sweetalert/sweetalert-dev.js @@ -0,0 +1,1240 @@ +;(function(window, document, undefined) { + "use strict"; + + (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o call showInputError with errorMessage + */ +sweetAlert.showInputError = swal.showInputError = function (errorMessage) { + var modal = _sweetAlertInitialize$getModal$getOverlay$getInput$setFocusStyle$openModal$resetInput$fixVerticalPosition.getModal(); + + var $errorIcon = modal.querySelector('.sa-input-error'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide$isDescendant$getTopMargin$fadeIn$fadeOut$fireClick$stopEventPropagation.addClass($errorIcon, 'show'); + + var $errorContainer = modal.querySelector('.sa-error-container'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide$isDescendant$getTopMargin$fadeIn$fadeOut$fireClick$stopEventPropagation.addClass($errorContainer, 'show'); + + $errorContainer.querySelector('p').innerHTML = errorMessage; + + modal.querySelector('input').focus(); +}; + +/* + * Reset input error DOM elements + */ +sweetAlert.resetInputError = swal.resetInputError = function (event) { + // If press enter => ignore + if (event && event.keyCode === 13) { + return false; + } + + var $modal = _sweetAlertInitialize$getModal$getOverlay$getInput$setFocusStyle$openModal$resetInput$fixVerticalPosition.getModal(); + + var $errorIcon = $modal.querySelector('.sa-input-error'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide$isDescendant$getTopMargin$fadeIn$fadeOut$fireClick$stopEventPropagation.removeClass($errorIcon, 'show'); + + var $errorContainer = $modal.querySelector('.sa-error-container'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide$isDescendant$getTopMargin$fadeIn$fadeOut$fireClick$stopEventPropagation.removeClass($errorContainer, 'show'); +}; + +if (typeof window !== 'undefined') { + // The 'handle-click' module requires + // that 'sweetAlert' was set as global. + window.sweetAlert = window.swal = sweetAlert; +} else { + _extend$hexToRgb$isIE8$logStr$colorLuminance.logStr('SweetAlert is a frontend module!'); +} + +},{"./modules/default-params":2,"./modules/handle-click":3,"./modules/handle-dom":4,"./modules/handle-key":5,"./modules/handle-swal-dom":6,"./modules/set-params":8,"./modules/utils":9}],2:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); +var defaultParams = { + title: '', + text: '', + type: null, + allowOutsideClick: false, + showConfirmButton: true, + showCancelButton: false, + closeOnConfirm: true, + closeOnCancel: true, + confirmButtonText: 'OK', + confirmButtonColor: '#AEDEF4', + cancelButtonText: 'Cancel', + imageUrl: null, + imageSize: null, + timer: null, + customClass: '', + html: false, + animation: true, + allowEscapeKey: true, + inputType: 'text', + inputPlaceholder: '', + inputValue: '' +}; + +exports['default'] = defaultParams; +module.exports = exports['default']; + +},{}],3:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); + +var _colorLuminance = require('./utils'); + +var _getModal = require('./handle-swal-dom'); + +var _hasClass$isDescendant = require('./handle-dom'); + +/* + * User clicked on "Confirm"/"OK" or "Cancel" + */ +var handleButton = function handleButton(event, params, modal) { + var e = event || window.event; + var target = e.target || e.srcElement; + + var targetedConfirm = target.className.indexOf('confirm') !== -1; + var targetedOverlay = target.className.indexOf('sweet-overlay') !== -1; + var modalIsVisible = _hasClass$isDescendant.hasClass(modal, 'visible'); + var doneFunctionExists = params.doneFunction && modal.getAttribute('data-has-done-function') === 'true'; + + // Since the user can change the background-color of the confirm button programmatically, + // we must calculate what the color should be on hover/active + var normalColor, hoverColor, activeColor; + if (targetedConfirm && params.confirmButtonColor) { + normalColor = params.confirmButtonColor; + hoverColor = _colorLuminance.colorLuminance(normalColor, -0.04); + activeColor = _colorLuminance.colorLuminance(normalColor, -0.14); + } + + function shouldSetConfirmButtonColor(color) { + if (targetedConfirm && params.confirmButtonColor) { + target.style.backgroundColor = color; + } + } + + switch (e.type) { + case 'mouseover': + shouldSetConfirmButtonColor(hoverColor); + break; + + case 'mouseout': + shouldSetConfirmButtonColor(normalColor); + break; + + case 'mousedown': + shouldSetConfirmButtonColor(activeColor); + break; + + case 'mouseup': + shouldSetConfirmButtonColor(hoverColor); + break; + + case 'focus': + var $confirmButton = modal.querySelector('button.confirm'); + var $cancelButton = modal.querySelector('button.cancel'); + + if (targetedConfirm) { + $cancelButton.style.boxShadow = 'none'; + } else { + $confirmButton.style.boxShadow = 'none'; + } + break; + + case 'click': + var clickedOnModal = modal === target; + var clickedOnModalChild = _hasClass$isDescendant.isDescendant(modal, target); + + // Ignore click outside if allowOutsideClick is false + if (!clickedOnModal && !clickedOnModalChild && modalIsVisible && !params.allowOutsideClick) { + break; + } + + if (targetedConfirm && doneFunctionExists && modalIsVisible) { + handleConfirm(modal, params); + } else if (doneFunctionExists && modalIsVisible || targetedOverlay) { + handleCancel(modal, params); + } else if (_hasClass$isDescendant.isDescendant(modal, target) && target.tagName === 'BUTTON') { + sweetAlert.close(); + } + break; + } +}; + +/* + * User clicked on "Confirm"/"OK" + */ +var handleConfirm = function handleConfirm(modal, params) { + var callbackValue = true; + + if (_hasClass$isDescendant.hasClass(modal, 'show-input')) { + callbackValue = modal.querySelector('input').value; + + if (!callbackValue) { + callbackValue = ''; + } + } + + params.doneFunction(callbackValue); + + if (params.closeOnConfirm) { + sweetAlert.close(); + } +}; + +/* + * User clicked on "Cancel" + */ +var handleCancel = function handleCancel(modal, params) { + // Check if callback function expects a parameter (to track cancel actions) + var functionAsStr = String(params.doneFunction).replace(/\s/g, ''); + var functionHandlesCancel = functionAsStr.substring(0, 9) === 'function(' && functionAsStr.substring(9, 10) !== ')'; + + if (functionHandlesCancel) { + params.doneFunction(false); + } + + if (params.closeOnCancel) { + sweetAlert.close(); + } +}; + +exports['default'] = { + handleButton: handleButton, + handleConfirm: handleConfirm, + handleCancel: handleCancel +}; +module.exports = exports['default']; + +},{"./handle-dom":4,"./handle-swal-dom":6,"./utils":9}],4:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); +var hasClass = function hasClass(elem, className) { + return new RegExp(' ' + className + ' ').test(' ' + elem.className + ' '); +}; + +var addClass = function addClass(elem, className) { + if (!hasClass(elem, className)) { + elem.className += ' ' + className; + } +}; + +var removeClass = function removeClass(elem, className) { + var newClass = ' ' + elem.className.replace(/[\t\r\n]/g, ' ') + ' '; + if (hasClass(elem, className)) { + while (newClass.indexOf(' ' + className + ' ') >= 0) { + newClass = newClass.replace(' ' + className + ' ', ' '); + } + elem.className = newClass.replace(/^\s+|\s+$/g, ''); + } +}; + +var escapeHtml = function escapeHtml(str) { + var div = document.createElement('div'); + div.appendChild(document.createTextNode(str)); + return div.innerHTML; +}; + +var _show = function _show(elem) { + elem.style.opacity = ''; + elem.style.display = 'block'; +}; + +var show = function show(elems) { + if (elems && !elems.length) { + return _show(elems); + } + for (var i = 0; i < elems.length; ++i) { + _show(elems[i]); + } +}; + +var _hide = function _hide(elem) { + elem.style.opacity = ''; + elem.style.display = 'none'; +}; + +var hide = function hide(elems) { + if (elems && !elems.length) { + return _hide(elems); + } + for (var i = 0; i < elems.length; ++i) { + _hide(elems[i]); + } +}; + +var isDescendant = function isDescendant(parent, child) { + var node = child.parentNode; + while (node !== null) { + if (node === parent) { + return true; + } + node = node.parentNode; + } + return false; +}; + +var getTopMargin = function getTopMargin(elem) { + elem.style.left = '-9999px'; + elem.style.display = 'block'; + + var height = elem.clientHeight, + padding; + if (typeof getComputedStyle !== 'undefined') { + // IE 8 + padding = parseInt(getComputedStyle(elem).getPropertyValue('padding-top'), 10); + } else { + padding = parseInt(elem.currentStyle.padding); + } + + elem.style.left = ''; + elem.style.display = 'none'; + return '-' + parseInt((height + padding) / 2) + 'px'; +}; + +var fadeIn = function fadeIn(elem, interval) { + if (+elem.style.opacity < 1) { + interval = interval || 16; + elem.style.opacity = 0; + elem.style.display = 'block'; + var last = +new Date(); + var tick = (function (_tick) { + function tick() { + return _tick.apply(this, arguments); + } + + tick.toString = function () { + return _tick.toString(); + }; + + return tick; + })(function () { + elem.style.opacity = +elem.style.opacity + (new Date() - last) / 100; + last = +new Date(); + + if (+elem.style.opacity < 1) { + setTimeout(tick, interval); + } + }); + tick(); + } + elem.style.display = 'block'; //fallback IE8 +}; + +var fadeOut = function fadeOut(elem, interval) { + interval = interval || 16; + elem.style.opacity = 1; + var last = +new Date(); + var tick = (function (_tick2) { + function tick() { + return _tick2.apply(this, arguments); + } + + tick.toString = function () { + return _tick2.toString(); + }; + + return tick; + })(function () { + elem.style.opacity = +elem.style.opacity - (new Date() - last) / 100; + last = +new Date(); + + if (+elem.style.opacity > 0) { + setTimeout(tick, interval); + } else { + elem.style.display = 'none'; + } + }); + tick(); +}; + +var fireClick = function fireClick(node) { + // Taken from http://www.nonobtrusive.com/2011/11/29/programatically-fire-crossbrowser-click-event-with-javascript/ + // Then fixed for today's Chrome browser. + if (typeof MouseEvent === 'function') { + // Up-to-date approach + var mevt = new MouseEvent('click', { + view: window, + bubbles: false, + cancelable: true + }); + node.dispatchEvent(mevt); + } else if (document.createEvent) { + // Fallback + var evt = document.createEvent('MouseEvents'); + evt.initEvent('click', false, false); + node.dispatchEvent(evt); + } else if (document.createEventObject) { + node.fireEvent('onclick'); + } else if (typeof node.onclick === 'function') { + node.onclick(); + } +}; + +var stopEventPropagation = function stopEventPropagation(e) { + // In particular, make sure the space bar doesn't scroll the main window. + if (typeof e.stopPropagation === 'function') { + e.stopPropagation(); + e.preventDefault(); + } else if (window.event && window.event.hasOwnProperty('cancelBubble')) { + window.event.cancelBubble = true; + } +}; + +exports.hasClass = hasClass; +exports.addClass = addClass; +exports.removeClass = removeClass; +exports.escapeHtml = escapeHtml; +exports._show = _show; +exports.show = show; +exports._hide = _hide; +exports.hide = hide; +exports.isDescendant = isDescendant; +exports.getTopMargin = getTopMargin; +exports.fadeIn = fadeIn; +exports.fadeOut = fadeOut; +exports.fireClick = fireClick; +exports.stopEventPropagation = stopEventPropagation; + +},{}],5:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); + +var _stopEventPropagation$fireClick = require('./handle-dom'); + +var _setFocusStyle = require('./handle-swal-dom'); + +var handleKeyDown = function handleKeyDown(event, params, modal) { + var e = event || window.event; + var keyCode = e.keyCode || e.which; + + var $okButton = modal.querySelector('button.confirm'); + var $cancelButton = modal.querySelector('button.cancel'); + var $modalButtons = modal.querySelectorAll('button[tabindex]'); + + if ([9, 13, 32, 27].indexOf(keyCode) === -1) { + // Don't do work on keys we don't care about. + return; + } + + var $targetElement = e.target || e.srcElement; + + var btnIndex = -1; // Find the button - note, this is a nodelist, not an array. + for (var i = 0; i < $modalButtons.length; i++) { + if ($targetElement === $modalButtons[i]) { + btnIndex = i; + break; + } + } + + if (keyCode === 9) { + // TAB + if (btnIndex === -1) { + // No button focused. Jump to the confirm button. + $targetElement = $okButton; + } else { + // Cycle to the next button + if (btnIndex === $modalButtons.length - 1) { + $targetElement = $modalButtons[0]; + } else { + $targetElement = $modalButtons[btnIndex + 1]; + } + } + + _stopEventPropagation$fireClick.stopEventPropagation(e); + $targetElement.focus(); + + if (params.confirmButtonColor) { + _setFocusStyle.setFocusStyle($targetElement, params.confirmButtonColor); + } + } else { + if (keyCode === 13) { + if ($targetElement.tagName === 'INPUT') { + $targetElement = $okButton; + $okButton.focus(); + } + + if (btnIndex === -1) { + // ENTER/SPACE clicked outside of a button. + $targetElement = $okButton; + } else { + // Do nothing - let the browser handle it. + $targetElement = undefined; + } + } else if (keyCode === 27 && params.allowEscapeKey === true) { + $targetElement = $cancelButton; + _stopEventPropagation$fireClick.fireClick($targetElement, e); + } else { + // Fallback - let the browser handle it. + $targetElement = undefined; + } + } +}; + +exports['default'] = handleKeyDown; +module.exports = exports['default']; + +},{"./handle-dom":4,"./handle-swal-dom":6}],6:[function(require,module,exports){ +'use strict'; + +var _interopRequireWildcard = function (obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }; + +Object.defineProperty(exports, '__esModule', { + value: true +}); + +var _hexToRgb = require('./utils'); + +var _removeClass$getTopMargin$fadeIn$show$addClass = require('./handle-dom'); + +var _defaultParams = require('./default-params'); + +var _defaultParams2 = _interopRequireWildcard(_defaultParams); + +/* + * Add modal + overlay to DOM + */ + +var _injectedHTML = require('./injected-html'); + +var _injectedHTML2 = _interopRequireWildcard(_injectedHTML); + +var modalClass = '.sweet-alert'; +var overlayClass = '.sweet-overlay'; + +var sweetAlertInitialize = function sweetAlertInitialize() { + var sweetWrap = document.createElement('div'); + sweetWrap.innerHTML = _injectedHTML2['default']; + + // Append elements to body + while (sweetWrap.firstChild) { + document.body.appendChild(sweetWrap.firstChild); + } +}; + +/* + * Get DOM element of modal + */ +var getModal = (function (_getModal) { + function getModal() { + return _getModal.apply(this, arguments); + } + + getModal.toString = function () { + return _getModal.toString(); + }; + + return getModal; +})(function () { + var $modal = document.querySelector(modalClass); + + if (!$modal) { + sweetAlertInitialize(); + $modal = getModal(); + } + + return $modal; +}); + +/* + * Get DOM element of input (in modal) + */ +var getInput = function getInput() { + var $modal = getModal(); + if ($modal) { + return $modal.querySelector('input'); + } +}; + +/* + * Get DOM element of overlay + */ +var getOverlay = function getOverlay() { + return document.querySelector(overlayClass); +}; + +/* + * Add box-shadow style to button (depending on its chosen bg-color) + */ +var setFocusStyle = function setFocusStyle($button, bgColor) { + var rgbColor = _hexToRgb.hexToRgb(bgColor); + $button.style.boxShadow = '0 0 2px rgba(' + rgbColor + ', 0.8), inset 0 0 0 1px rgba(0, 0, 0, 0.05)'; +}; + +/* + * Animation when opening modal + */ +var openModal = function openModal(callback) { + var $modal = getModal(); + _removeClass$getTopMargin$fadeIn$show$addClass.fadeIn(getOverlay(), 10); + _removeClass$getTopMargin$fadeIn$show$addClass.show($modal); + _removeClass$getTopMargin$fadeIn$show$addClass.addClass($modal, 'showSweetAlert'); + _removeClass$getTopMargin$fadeIn$show$addClass.removeClass($modal, 'hideSweetAlert'); + + window.previousActiveElement = document.activeElement; + var $okButton = $modal.querySelector('button.confirm'); + $okButton.focus(); + + setTimeout(function () { + _removeClass$getTopMargin$fadeIn$show$addClass.addClass($modal, 'visible'); + }, 500); + + var timer = $modal.getAttribute('data-timer'); + + if (timer !== 'null' && timer !== '') { + var timerCallback = callback; + $modal.timeout = setTimeout(function () { + var doneFunctionExists = (timerCallback || null) && $modal.getAttribute('data-has-done-function') === 'true'; + if (doneFunctionExists) { + timerCallback(null); + } else { + sweetAlert.close(); + } + }, timer); + } +}; + +/* + * Reset the styling of the input + * (for example if errors have been shown) + */ +var resetInput = function resetInput() { + var $modal = getModal(); + var $input = getInput(); + + _removeClass$getTopMargin$fadeIn$show$addClass.removeClass($modal, 'show-input'); + $input.value = _defaultParams2['default'].inputValue; + $input.setAttribute('type', _defaultParams2['default'].inputType); + $input.setAttribute('placeholder', _defaultParams2['default'].inputPlaceholder); + + resetInputError(); +}; + +var resetInputError = function resetInputError(event) { + // If press enter => ignore + if (event && event.keyCode === 13) { + return false; + } + + var $modal = getModal(); + + var $errorIcon = $modal.querySelector('.sa-input-error'); + _removeClass$getTopMargin$fadeIn$show$addClass.removeClass($errorIcon, 'show'); + + var $errorContainer = $modal.querySelector('.sa-error-container'); + _removeClass$getTopMargin$fadeIn$show$addClass.removeClass($errorContainer, 'show'); +}; + +/* + * Set "margin-top"-property on modal based on its computed height + */ +var fixVerticalPosition = function fixVerticalPosition() { + var $modal = getModal(); + $modal.style.marginTop = _removeClass$getTopMargin$fadeIn$show$addClass.getTopMargin(getModal()); +}; + +exports.sweetAlertInitialize = sweetAlertInitialize; +exports.getModal = getModal; +exports.getOverlay = getOverlay; +exports.getInput = getInput; +exports.setFocusStyle = setFocusStyle; +exports.openModal = openModal; +exports.resetInput = resetInput; +exports.resetInputError = resetInputError; +exports.fixVerticalPosition = fixVerticalPosition; + +},{"./default-params":2,"./handle-dom":4,"./injected-html":7,"./utils":9}],7:[function(require,module,exports){ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var injectedHTML = + +// Dark overlay +"
" + + +// Modal +"
" + + +// Error icon +"
\n \n \n \n \n
" + + +// Warning icon +"
\n \n \n
" + + +// Info icon +"
" + + +// Success icon +"
\n \n \n\n
\n
\n
" + "
" + + +// Title, text and input +"

Title

\n

Text

\n
\n \n
\n
" + + +// Input errors +"
\n
!
\n

Not valid!

\n
" + + +// Cancel and confirm buttons +"
\n \n \n
" + + +// End of modal +"
"; + +exports["default"] = injectedHTML; +module.exports = exports["default"]; + +},{}],8:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); + +var _isIE8 = require('./utils'); + +var _getModal$getInput$setFocusStyle = require('./handle-swal-dom'); + +var _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide = require('./handle-dom'); + +var alertTypes = ['error', 'warning', 'info', 'success', 'input', 'prompt']; + +/* + * Set type, text and actions on modal + */ +var setParameters = function setParameters(params) { + var modal = _getModal$getInput$setFocusStyle.getModal(); + + var $title = modal.querySelector('h2'); + var $text = modal.querySelector('p'); + var $cancelBtn = modal.querySelector('button.cancel'); + var $confirmBtn = modal.querySelector('button.confirm'); + + /* + * Title + */ + $title.innerHTML = params.html ? params.title : _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.escapeHtml(params.title).split('\n').join('
'); + + /* + * Text + */ + $text.innerHTML = params.html ? params.text : _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.escapeHtml(params.text || '').split('\n').join('
'); + if (params.text) _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.show($text); + + /* + * Custom class + */ + if (params.customClass) { + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass(modal, params.customClass); + modal.setAttribute('data-custom-class', params.customClass); + } else { + // Find previously set classes and remove them + var customClass = modal.getAttribute('data-custom-class'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.removeClass(modal, customClass); + modal.setAttribute('data-custom-class', ''); + } + + /* + * Icon + */ + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.hide(modal.querySelectorAll('.sa-icon')); + + if (params.type && !_isIE8.isIE8()) { + var _ret = (function () { + + var validType = false; + + for (var i = 0; i < alertTypes.length; i++) { + if (params.type === alertTypes[i]) { + validType = true; + break; + } + } + + if (!validType) { + logStr('Unknown alert type: ' + params.type); + return { + v: false + }; + } + + var typesWithIcons = ['success', 'error', 'warning', 'info']; + var $icon = undefined; + + if (typesWithIcons.indexOf(params.type) !== -1) { + $icon = modal.querySelector('.sa-icon.' + 'sa-' + params.type); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.show($icon); + } + + var $input = _getModal$getInput$setFocusStyle.getInput(); + + // Animate icon + switch (params.type) { + + case 'success': + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon, 'animate'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon.querySelector('.sa-tip'), 'animateSuccessTip'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon.querySelector('.sa-long'), 'animateSuccessLong'); + break; + + case 'error': + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon, 'animateErrorIcon'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon.querySelector('.sa-x-mark'), 'animateXMark'); + break; + + case 'warning': + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon, 'pulseWarning'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon.querySelector('.sa-body'), 'pulseWarningIns'); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass($icon.querySelector('.sa-dot'), 'pulseWarningIns'); + break; + + case 'input': + case 'prompt': + $input.setAttribute('type', params.inputType); + $input.value = params.inputValue; + $input.setAttribute('placeholder', params.inputPlaceholder); + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.addClass(modal, 'show-input'); + setTimeout(function () { + $input.focus(); + $input.addEventListener('keyup', swal.resetInputError); + }, 400); + break; + } + })(); + + if (typeof _ret === 'object') { + return _ret.v; + } + } + + /* + * Custom image + */ + if (params.imageUrl) { + var $customIcon = modal.querySelector('.sa-icon.sa-custom'); + + $customIcon.style.backgroundImage = 'url(' + params.imageUrl + ')'; + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.show($customIcon); + + var _imgWidth = 80; + var _imgHeight = 80; + + if (params.imageSize) { + var dimensions = params.imageSize.toString().split('x'); + var imgWidth = dimensions[0]; + var imgHeight = dimensions[1]; + + if (!imgWidth || !imgHeight) { + logStr('Parameter imageSize expects value with format WIDTHxHEIGHT, got ' + params.imageSize); + } else { + _imgWidth = imgWidth; + _imgHeight = imgHeight; + } + } + + $customIcon.setAttribute('style', $customIcon.getAttribute('style') + 'width:' + _imgWidth + 'px; height:' + _imgHeight + 'px'); + } + + /* + * Show cancel button? + */ + modal.setAttribute('data-has-cancel-button', params.showCancelButton); + if (params.showCancelButton) { + $cancelBtn.style.display = 'inline-block'; + } else { + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.hide($cancelBtn); + } + + /* + * Show confirm button? + */ + modal.setAttribute('data-has-confirm-button', params.showConfirmButton); + if (params.showConfirmButton) { + $confirmBtn.style.display = 'inline-block'; + } else { + _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.hide($confirmBtn); + } + + /* + * Custom text on cancel/confirm buttons + */ + if (params.cancelButtonText) { + $cancelBtn.innerHTML = _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.escapeHtml(params.cancelButtonText); + } + if (params.confirmButtonText) { + $confirmBtn.innerHTML = _hasClass$addClass$removeClass$escapeHtml$_show$show$_hide$hide.escapeHtml(params.confirmButtonText); + } + + /* + * Custom color on confirm button + */ + if (params.confirmButtonColor) { + // Set confirm button to selected background color + $confirmBtn.style.backgroundColor = params.confirmButtonColor; + + // Set box-shadow to default focused button + _getModal$getInput$setFocusStyle.setFocusStyle($confirmBtn, params.confirmButtonColor); + } + + /* + * Allow outside click + */ + modal.setAttribute('data-allow-outside-click', params.allowOutsideClick); + + /* + * Callback function + */ + var hasDoneFunction = params.doneFunction ? true : false; + modal.setAttribute('data-has-done-function', hasDoneFunction); + + /* + * Animation + */ + if (!params.animation) { + modal.setAttribute('data-animation', 'none'); + } else if (typeof params.animation === 'string') { + modal.setAttribute('data-animation', params.animation); // Custom animation + } else { + modal.setAttribute('data-animation', 'pop'); + } + + /* + * Timer + */ + modal.setAttribute('data-timer', params.timer); +}; + +exports['default'] = setParameters; +module.exports = exports['default']; + +},{"./handle-dom":4,"./handle-swal-dom":6,"./utils":9}],9:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, '__esModule', { + value: true +}); +/* + * Allow user to pass their own params + */ +var extend = function extend(a, b) { + for (var key in b) { + if (b.hasOwnProperty(key)) { + a[key] = b[key]; + } + } + return a; +}; + +/* + * Convert HEX codes to RGB values (#000000 -> rgb(0,0,0)) + */ +var hexToRgb = function hexToRgb(hex) { + var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); + return result ? parseInt(result[1], 16) + ', ' + parseInt(result[2], 16) + ', ' + parseInt(result[3], 16) : null; +}; + +/* + * Check if the user is using Internet Explorer 8 (for fallbacks) + */ +var isIE8 = function isIE8() { + return window.attachEvent && !window.addEventListener; +}; + +/* + * IE compatible logging for developers + */ +var logStr = function logStr(string) { + if (window.console) { + // IE... + window.console.log('SweetAlert: ' + string); + } +}; + +/* + * Set hover, active and focus-states for buttons + * (source: http://www.sitepoint.com/javascript-generate-lighter-darker-color) + */ +var colorLuminance = function colorLuminance(hex, lum) { + // Validate hex string + hex = String(hex).replace(/[^0-9a-f]/gi, ''); + if (hex.length < 6) { + hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2]; + } + lum = lum || 0; + + // Convert to decimal and change luminosity + var rgb = '#'; + var c; + var i; + + for (i = 0; i < 3; i++) { + c = parseInt(hex.substr(i * 2, 2), 16); + c = Math.round(Math.min(Math.max(0, c + c * lum), 255)).toString(16); + rgb += ('00' + c).substr(c.length); + } + + return rgb; +}; + +exports.extend = extend; +exports.hexToRgb = hexToRgb; +exports.isIE8 = isIE8; +exports.logStr = logStr; +exports.colorLuminance = colorLuminance; + +},{}]},{},[1]) +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/Tristan/dev/SweetAlert/dev/sweetalert.es6.js","/Users/Tristan/dev/SweetAlert/dev/modules/default-params.js","/Users/Tristan/dev/SweetAlert/dev/modules/handle-click.js","/Users/Tristan/dev/SweetAlert/dev/modules/handle-dom.js","/Users/Tristan/dev/SweetAlert/dev/modules/handle-key.js","/Users/Tristan/dev/SweetAlert/dev/modules/handle-swal-dom.js","/Users/Tristan/dev/SweetAlert/dev/modules/injected-html.js","/Users/Tristan/dev/SweetAlert/dev/modules/set-params.js","/Users/Tristan/dev/SweetAlert/dev/modules/utils.js"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;sJCgBO,sBAAsB;;;;;;2DAWtB,iBAAiB;;;;;;wHAcjB,2BAA2B;;;;uDAIwB,wBAAwB;;6BACxD,sBAAsB;;;;;;6BAItB,0BAA0B;;;;6BAC1B,sBAAsB;;;;;;;;AAMhD,IAAI,qBAAqB,CAAC;AAC1B,IAAI,iBAAiB,CAAC;;;;;;AAOtB,IAAI,UAAU,EAAE,IAAI,CAAC;;AAErB,UAAU,GAAG,IAAI,GAAG,YAAW;AAC7B,MAAI,cAAc,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;;AAElC,0IA9DU,QAAQ,CA8DT,QAAQ,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;AAC1C,4GAhCA,UAAU,EAgCE,CAAC;;;;;;;AAOb,WAAS,iBAAiB,CAAC,GAAG,EAAE;AAC9B,QAAI,IAAI,GAAG,cAAc,CAAC;AAC1B,WAAO,AAAC,IAAI,CAAC,GAAG,CAAC,KAAK,SAAS,GAAK,2BAAc,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;GACpE;;AAED,MAAI,cAAc,KAAK,SAAS,EAAE;AAChC,iDA3DF,MAAM,CA2DG,0CAA0C,CAAC,CAAC;AACnD,WAAO,KAAK,CAAC;GACd;;AAED,MAAI,MAAM,GAAG,6CAlEb,MAAM,CAkEc,EAAE,6BAAgB,CAAC;;AAEvC,UAAQ,OAAO,cAAc;;;AAG3B,SAAK,QAAQ;AACX,YAAM,CAAC,KAAK,GAAG,cAAc,CAAC;AAC9B,YAAM,CAAC,IAAI,GAAI,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;AAClC,YAAM,CAAC,IAAI,GAAI,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;AAClC,YAAM;;AAAA;AAGR,SAAK,QAAQ;AACX,UAAI,cAAc,CAAC,KAAK,KAAK,SAAS,EAAE;AACtC,qDA7EN,MAAM,CA6EO,2BAA2B,CAAC,CAAC;AACpC,eAAO,KAAK,CAAC;OACd;;AAED,YAAM,CAAC,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC;;AAEpC,WAAK,IAAI,UAAU,gCAAmB;AACpC,cAAM,CAAC,UAAU,CAAC,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;OACpD;;;AAGD,YAAM,CAAC,iBAAiB,GAAG,MAAM,CAAC,gBAAgB,GAAG,SAAS,GAAG,2BAAc,iBAAiB,CAAC;AACjG,YAAM,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,mBAAmB,CAAC,CAAC;;;AAGlE,YAAM,CAAC,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;;AAE3C,YAAM;;AAAA,AAER;AACE,mDAjGJ,MAAM,CAiGK,kEAAkE,GAAG,OAAO,cAAc,CAAC,CAAC;AACnG,aAAO,KAAK,CAAC;;AAAA,GAEhB;;AAED,6BAAc,MAAM,CAAC,CAAC;AACtB,4GAxFA,mBAAmB,EAwFE,CAAC;AACtB,4GA3FA,SAAS,CA2FC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;;;AAGxB,MAAI,KAAK,GAAG,0GAlGZ,QAAQ,EAkGc,CAAC;;;;;AAMvB,MAAI,QAAQ,GAAG,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;AAChD,MAAI,YAAY,GAAG,CAAC,SAAS,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;AACnG,MAAI,aAAa,GAAG,uBAAC,CAAC;WAAK,yCA/FpB,YAAY,CA+FqB,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC;GAAA,CAAC;;AAE1D,OAAK,IAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;AAC7D,SAAK,IAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;AACjE,UAAI,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpC,cAAQ,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,GAAG,aAAa,CAAC;KAC5C;GACF;;;AAGD,4GAnHA,UAAU,EAmHE,CAAC,OAAO,GAAG,aAAa,CAAC;;AAErC,uBAAqB,GAAG,MAAM,CAAC,SAAS,CAAC;;AAEzC,MAAI,UAAU,GAAG,oBAAC,CAAC;WAAK,2BAAc,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC;GAAA,CAAC;AACxD,QAAM,CAAC,SAAS,GAAG,UAAU,CAAC;;AAE9B,QAAM,CAAC,OAAO,GAAG,YAAY;;AAE3B,cAAU,CAAC,YAAY;;;AAGrB,UAAI,iBAAiB,KAAK,SAAS,EAAE;AACnC,yBAAiB,CAAC,KAAK,EAAE,CAAC;AAC1B,yBAAiB,GAAG,SAAS,CAAC;OAC/B;KACF,EAAE,CAAC,CAAC,CAAC;GACP,CAAC;CACH,CAAC;;;;;;AAQF,UAAU,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,GAAG,UAAS,UAAU,EAAE;AAC/D,MAAI,CAAC,UAAU,EAAE;AACf,UAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;GAC3C;AACD,MAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;AAClC,UAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;GAClD;;AAED,+CAlKA,MAAM,6BAkKgB,UAAU,CAAC,CAAC;CACnC,CAAC;;;;;AAMF,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,YAAW;AACzC,MAAI,KAAK,GAAG,0GA9JZ,QAAQ,EA8Jc,CAAC;;AAEvB,0IArLQ,OAAO,CAqLP,0GA/JR,UAAU,EA+JU,EAAE,CAAC,CAAC,CAAC;AACzB,0IAtLQ,OAAO,CAsLP,KAAK,EAAE,CAAC,CAAC,CAAC;AAClB,0IA5LoB,WAAW,CA4LnB,KAAK,EAAE,gBAAgB,CAAC,CAAC;AACrC,0IA7LU,QAAQ,CA6LT,KAAK,EAAE,gBAAgB,CAAC,CAAC;AAClC,0IA9LoB,WAAW,CA8LnB,KAAK,EAAE,SAAS,CAAC,CAAC;;;;;AAK9B,MAAI,YAAY,GAAG,KAAK,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;AAC9D,0IApMoB,WAAW,CAoMnB,YAAY,EAAE,SAAS,CAAC,CAAC;AACrC,0IArMoB,WAAW,CAqMnB,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,mBAAmB,CAAC,CAAC;AACxE,0IAtMoB,WAAW,CAsMnB,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,oBAAoB,CAAC,CAAC;;AAE1E,MAAI,UAAU,GAAG,KAAK,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;AAC1D,0IAzMoB,WAAW,CAyMnB,UAAU,EAAE,kBAAkB,CAAC,CAAC;AAC5C,0IA1MoB,WAAW,CA0MnB,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,EAAE,cAAc,CAAC,CAAC;;AAEpE,MAAI,YAAY,GAAG,KAAK,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;AAC9D,0IA7MoB,WAAW,CA6MnB,YAAY,EAAE,cAAc,CAAC,CAAC;AAC1C,0IA9MoB,WAAW,CA8MnB,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,iBAAiB,CAAC,CAAC;AACvE,0IA/MoB,WAAW,CA+MnB,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,iBAAiB,CAAC,CAAC;;;AAGtE,YAAU,CAAC,YAAW;AACpB,QAAI,WAAW,GAAG,KAAK,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;AAC1D,4IApNkB,WAAW,CAoNjB,KAAK,EAAE,WAAW,CAAC,CAAC;GACjC,EAAE,GAAG,CAAC,CAAC;;;AAGR,0IAxNoB,WAAW,CAwNnB,QAAQ,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;;;AAG7C,QAAM,CAAC,SAAS,GAAG,qBAAqB,CAAC;AACzC,MAAI,MAAM,CAAC,qBAAqB,EAAE;AAChC,UAAM,CAAC,qBAAqB,CAAC,KAAK,EAAE,CAAC;GACtC;AACD,mBAAiB,GAAG,SAAS,CAAC;AAC9B,cAAY,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;;AAE5B,SAAO,IAAI,CAAC;CACb,CAAC;;;;;;AAOF,UAAU,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,GAAG,UAAS,YAAY,EAAE;AACvE,MAAI,KAAK,GAAG,0GAjNZ,QAAQ,EAiNc,CAAC;;AAEvB,MAAI,UAAU,GAAG,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;AACxD,0IA9OU,QAAQ,CA8OT,UAAU,EAAE,MAAM,CAAC,CAAC;;AAE7B,MAAI,eAAe,GAAG,KAAK,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;AACjE,0IAjPU,QAAQ,CAiPT,eAAe,EAAE,MAAM,CAAC,CAAC;;AAElC,iBAAe,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,SAAS,GAAG,YAAY,CAAC;;AAE5D,OAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC;CACtC,CAAC;;;;;AAMF,UAAU,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,GAAG,UAAS,KAAK,EAAE;;AAElE,MAAI,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,EAAE;AACjC,WAAO,KAAK,CAAC;GACd;;AAED,MAAI,MAAM,GAAG,0GAxOb,QAAQ,EAwOe,CAAC;;AAExB,MAAI,UAAU,GAAG,MAAM,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;AACzD,0IArQoB,WAAW,CAqQnB,UAAU,EAAE,MAAM,CAAC,CAAC;;AAEhC,MAAI,eAAe,GAAG,MAAM,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;AAClE,0IAxQoB,WAAW,CAwQnB,eAAe,EAAE,MAAM,CAAC,CAAC;CACtC,CAAC;;AAEF,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;;;AAGjC,QAAM,CAAC,UAAU,GAAG,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC;CAC9C,MAAM;AACL,+CA/PA,MAAM,CA+PC,kCAAkC,CAAC,CAAC;CAC5C;;;;;;;;ACzRD,IAAI,aAAa,GAAG;AAClB,OAAK,EAAE,EAAE;AACT,MAAI,EAAE,EAAE;AACR,MAAI,EAAE,IAAI;AACV,mBAAiB,EAAE,KAAK;AACxB,mBAAiB,EAAE,IAAI;AACvB,kBAAgB,EAAE,KAAK;AACvB,gBAAc,EAAE,IAAI;AACpB,eAAa,EAAE,IAAI;AACnB,mBAAiB,EAAE,IAAI;AACvB,oBAAkB,EAAE,SAAS;AAC7B,kBAAgB,EAAE,QAAQ;AAC1B,UAAQ,EAAE,IAAI;AACd,WAAS,EAAE,IAAI;AACf,OAAK,EAAE,IAAI;AACX,aAAW,EAAE,EAAE;AACf,MAAI,EAAE,KAAK;AACX,WAAS,EAAE,IAAI;AACf,gBAAc,EAAE,IAAI;AACpB,WAAS,EAAE,MAAM;AACjB,kBAAgB,EAAE,EAAE;AACpB,YAAU,EAAE,EAAE;CACf,CAAC;;qBAEa,aAAa;;;;;;;;;;8BCxBG,SAAS;;wBACf,mBAAmB;;qCACL,cAAc;;;;;AAMrD,IAAI,YAAY,GAAG,sBAAS,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;AAChD,MAAI,CAAC,GAAG,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC;AAC9B,MAAI,MAAM,GAAG,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,UAAU,CAAC;;AAEtC,MAAI,eAAe,GAAG,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;AACjE,MAAI,eAAe,GAAG,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;AACvE,MAAI,cAAc,GAAI,uBAZf,QAAQ,CAYgB,KAAK,EAAE,SAAS,CAAC,CAAC;AACjD,MAAI,kBAAkB,GAAI,MAAM,CAAC,YAAY,IAAI,KAAK,CAAC,YAAY,CAAC,wBAAwB,CAAC,KAAK,MAAM,AAAC,CAAC;;;;AAI1G,MAAI,WAAW,EAAE,UAAU,EAAE,WAAW,CAAC;AACzC,MAAI,eAAe,IAAI,MAAM,CAAC,kBAAkB,EAAE;AAChD,eAAW,GAAI,MAAM,CAAC,kBAAkB,CAAC;AACzC,cAAU,GAAK,gBAtBV,cAAc,CAsBW,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;AAClD,eAAW,GAAI,gBAvBV,cAAc,CAuBW,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;GACnD;;AAED,WAAS,2BAA2B,CAAC,KAAK,EAAE;AAC1C,QAAI,eAAe,IAAI,MAAM,CAAC,kBAAkB,EAAE;AAChD,YAAM,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;KACtC;GACF;;AAED,UAAQ,CAAC,CAAC,IAAI;AACZ,SAAK,WAAW;AACd,iCAA2B,CAAC,UAAU,CAAC,CAAC;AACxC,YAAM;;AAAA,AAER,SAAK,UAAU;AACb,iCAA2B,CAAC,WAAW,CAAC,CAAC;AACzC,YAAM;;AAAA,AAER,SAAK,WAAW;AACd,iCAA2B,CAAC,WAAW,CAAC,CAAC;AACzC,YAAM;;AAAA,AAER,SAAK,SAAS;AACZ,iCAA2B,CAAC,UAAU,CAAC,CAAC;AACxC,YAAM;;AAAA,AAER,SAAK,OAAO;AACV,UAAI,cAAc,GAAG,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;AAC3D,UAAI,aAAa,GAAI,KAAK,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;;AAE1D,UAAI,eAAe,EAAE;AACnB,qBAAa,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC;OACxC,MAAM;AACL,sBAAc,CAAC,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC;OACzC;AACD,YAAM;;AAAA,AAER,SAAK,OAAO;AACV,UAAI,cAAc,GAAI,KAAK,KAAK,MAAM,AAAC,CAAC;AACxC,UAAI,mBAAmB,GAAG,uBA5Db,YAAY,CA4Dc,KAAK,EAAE,MAAM,CAAC,CAAC;;;AAGtD,UAAI,CAAC,cAAc,IAAI,CAAC,mBAAmB,IAAI,cAAc,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE;AAC1F,cAAM;OACP;;AAED,UAAI,eAAe,IAAI,kBAAkB,IAAI,cAAc,EAAE;AAC3D,qBAAa,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;OAC9B,MAAM,IAAI,kBAAkB,IAAI,cAAc,IAAI,eAAe,EAAE;AAClE,oBAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;OAC7B,MAAM,IAAI,uBAvEE,YAAY,CAuED,KAAK,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,KAAK,QAAQ,EAAE;AACrE,kBAAU,CAAC,KAAK,EAAE,CAAC;OACpB;AACD,YAAM;AAAA,GACT;CACF,CAAC;;;;;AAKF,IAAI,aAAa,GAAG,uBAAS,KAAK,EAAE,MAAM,EAAE;AAC1C,MAAI,aAAa,GAAG,IAAI,CAAC;;AAEzB,MAAI,uBApFG,QAAQ,CAoFF,KAAK,EAAE,YAAY,CAAC,EAAE;AACjC,iBAAa,GAAG,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC;;AAEnD,QAAI,CAAC,aAAa,EAAE;AAClB,mBAAa,GAAG,EAAE,CAAC;KACpB;GACF;;AAED,QAAM,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;;AAEnC,MAAI,MAAM,CAAC,cAAc,EAAE;AACzB,cAAU,CAAC,KAAK,EAAE,CAAC;GACpB;CACF,CAAC;;;;;AAKF,IAAI,YAAY,GAAG,sBAAS,KAAK,EAAE,MAAM,EAAE;;AAEzC,MAAI,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;AACnE,MAAI,qBAAqB,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,WAAW,IAAI,aAAa,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,GAAG,CAAC;;AAEpH,MAAI,qBAAqB,EAAE;AACzB,UAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;GAC5B;;AAED,MAAI,MAAM,CAAC,aAAa,EAAE;AACxB,cAAU,CAAC,KAAK,EAAE,CAAC;GACpB;CACF,CAAC;;qBAGa;AACb,cAAY,EAAZ,YAAY;AACZ,eAAa,EAAb,aAAa;AACb,cAAY,EAAZ,YAAY;CACb;;;;;;;;;AC3HD,IAAI,QAAQ,GAAG,kBAAS,IAAI,EAAE,SAAS,EAAE;AACvC,SAAO,IAAI,MAAM,CAAC,GAAG,GAAG,SAAS,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC;CAC3E,CAAC;;AAEF,IAAI,QAAQ,GAAG,kBAAS,IAAI,EAAE,SAAS,EAAE;AACvC,MAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE;AAC9B,QAAI,CAAC,SAAS,IAAI,GAAG,GAAG,SAAS,CAAC;GACnC;CACF,CAAC;;AAEF,IAAI,WAAW,GAAG,qBAAS,IAAI,EAAE,SAAS,EAAE;AAC1C,MAAI,QAAQ,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,EAAE,GAAG,CAAC,GAAG,GAAG,CAAC;AACpE,MAAI,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE;AAC7B,WAAO,QAAQ,CAAC,OAAO,CAAC,GAAG,GAAG,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC,EAAE;AACnD,cAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,GAAG,SAAS,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;KACzD;AACD,QAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;GACrD;CACF,CAAC;;AAEF,IAAI,UAAU,GAAG,oBAAS,GAAG,EAAE;AAC7B,MAAI,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AACxC,KAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9C,SAAO,GAAG,CAAC,SAAS,CAAC;CACtB,CAAC;;AAEF,IAAI,KAAK,GAAG,eAAS,IAAI,EAAE;AACzB,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC;AACxB,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;CAC9B,CAAC;;AAEF,IAAI,IAAI,GAAG,cAAS,KAAK,EAAE;AACzB,MAAI,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;AAC1B,WAAO,KAAK,CAAC,KAAK,CAAC,CAAC;GACrB;AACD,OAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;AACrC,SAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;GACjB;CACF,CAAC;;AAEF,IAAI,KAAK,GAAG,eAAS,IAAI,EAAE;AACzB,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC;AACxB,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;CAC7B,CAAC;;AAEF,IAAI,IAAI,GAAG,cAAS,KAAK,EAAE;AACzB,MAAI,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;AAC1B,WAAO,KAAK,CAAC,KAAK,CAAC,CAAC;GACrB;AACD,OAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;AACrC,SAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;GACjB;CACF,CAAC;;AAEF,IAAI,YAAY,GAAG,sBAAS,MAAM,EAAE,KAAK,EAAE;AACzC,MAAI,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC;AAC5B,SAAO,IAAI,KAAK,IAAI,EAAE;AACpB,QAAI,IAAI,KAAK,MAAM,EAAE;AACnB,aAAO,IAAI,CAAC;KACb;AACD,QAAI,GAAG,IAAI,CAAC,UAAU,CAAC;GACxB;AACD,SAAO,KAAK,CAAC;CACd,CAAC;;AAEF,IAAI,YAAY,GAAG,sBAAS,IAAI,EAAE;AAChC,MAAI,CAAC,KAAK,CAAC,IAAI,GAAG,SAAS,CAAC;AAC5B,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;;AAE7B,MAAI,MAAM,GAAG,IAAI,CAAC,YAAY;MAC1B,OAAO,CAAC;AACZ,MAAI,OAAO,gBAAgB,KAAK,WAAW,EAAE;;AAC3C,WAAO,GAAG,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;GAChF,MAAM;AACL,WAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;GAC/C;;AAED,MAAI,CAAC,KAAK,CAAC,IAAI,GAAG,EAAE,CAAC;AACrB,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;AAC5B,SAAQ,GAAG,GAAG,QAAQ,CAAC,CAAC,MAAM,GAAG,OAAO,CAAA,GAAI,CAAC,CAAC,GAAG,IAAI,CAAE;CACxD,CAAC;;AAEF,IAAI,MAAM,GAAG,gBAAS,IAAI,EAAE,QAAQ,EAAE;AACpC,MAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,EAAE;AAC3B,YAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;AAC1B,QAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;AACvB,QAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;AAC7B,QAAI,IAAI,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;AACvB,QAAI,IAAI;;;;;;;;;;OAAG,YAAW;AACpB,UAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,IAAI,IAAI,EAAE,GAAG,IAAI,CAAA,GAAI,GAAG,CAAC;AACrE,UAAI,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;;AAEnB,UAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,EAAE;AAC3B,kBAAU,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;OAC5B;KACF,CAAA,CAAC;AACF,QAAI,EAAE,CAAC;GACR;AACD,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;CAC9B,CAAC;;AAEF,IAAI,OAAO,GAAG,iBAAS,IAAI,EAAE,QAAQ,EAAE;AACrC,UAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;AAC1B,MAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;AACvB,MAAI,IAAI,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;AACvB,MAAI,IAAI;;;;;;;;;;KAAG,YAAW;AACpB,QAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,IAAI,IAAI,EAAE,GAAG,IAAI,CAAA,GAAI,GAAG,CAAC;AACrE,QAAI,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;;AAEnB,QAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,EAAE;AAC3B,gBAAU,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;KAC5B,MAAM;AACL,UAAI,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;KAC7B;GACF,CAAA,CAAC;AACF,MAAI,EAAE,CAAC;CACR,CAAC;;AAEF,IAAI,SAAS,GAAG,mBAAS,IAAI,EAAE;;;AAG7B,MAAI,OAAO,UAAU,KAAK,UAAU,EAAE;;AAEpC,QAAI,IAAI,GAAG,IAAI,UAAU,CAAC,OAAO,EAAE;AACjC,UAAI,EAAE,MAAM;AACZ,aAAO,EAAE,KAAK;AACd,gBAAU,EAAE,IAAI;KACjB,CAAC,CAAC;AACH,QAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;GAC1B,MAAM,IAAK,QAAQ,CAAC,WAAW,EAAG;;AAEjC,QAAI,GAAG,GAAG,QAAQ,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;AAC9C,OAAG,CAAC,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AACrC,QAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;GACzB,MAAM,IAAI,QAAQ,CAAC,iBAAiB,EAAE;AACrC,QAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAE;GAC5B,MAAM,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,EAAG;AAC9C,QAAI,CAAC,OAAO,EAAE,CAAC;GAChB;CACF,CAAC;;AAEF,IAAI,oBAAoB,GAAG,8BAAS,CAAC,EAAE;;AAErC,MAAI,OAAO,CAAC,CAAC,eAAe,KAAK,UAAU,EAAE;AAC3C,KAAC,CAAC,eAAe,EAAE,CAAC;AACpB,KAAC,CAAC,cAAc,EAAE,CAAC;GACpB,MAAM,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE;AACtE,UAAM,CAAC,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC;GAClC;CACF,CAAC;;QAGA,QAAQ,GAAR,QAAQ;QAAE,QAAQ,GAAR,QAAQ;QAAE,WAAW,GAAX,WAAW;QAC/B,UAAU,GAAV,UAAU;QACV,KAAK,GAAL,KAAK;QAAE,IAAI,GAAJ,IAAI;QAAE,KAAK,GAAL,KAAK;QAAE,IAAI,GAAJ,IAAI;QACxB,YAAY,GAAZ,YAAY;QACZ,YAAY,GAAZ,YAAY;QACZ,MAAM,GAAN,MAAM;QAAE,OAAO,GAAP,OAAO;QACf,SAAS,GAAT,SAAS;QACT,oBAAoB,GAApB,oBAAoB;;;;;;;;;8CC/J0B,cAAc;;6BAChC,mBAAmB;;AAGjD,IAAI,aAAa,GAAG,uBAAS,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;AACjD,MAAI,CAAC,GAAG,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC;AAC9B,MAAI,OAAO,GAAG,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,KAAK,CAAC;;AAEnC,MAAI,SAAS,GAAO,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;AAC1D,MAAI,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;AACzD,MAAI,aAAa,GAAG,KAAK,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;;AAG/D,MAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE;;AAE3C,WAAO;GACR;;AAED,MAAI,cAAc,GAAG,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,UAAU,CAAC;;AAE9C,MAAI,QAAQ,GAAG,CAAC,CAAC,CAAC;AAClB,OAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AAC7C,QAAI,cAAc,KAAK,aAAa,CAAC,CAAC,CAAC,EAAE;AACvC,cAAQ,GAAG,CAAC,CAAC;AACb,YAAM;KACP;GACF;;AAED,MAAI,OAAO,KAAK,CAAC,EAAE;;AAEjB,QAAI,QAAQ,KAAK,CAAC,CAAC,EAAE;;AAEnB,oBAAc,GAAG,SAAS,CAAC;KAC5B,MAAM;;AAEL,UAAI,QAAQ,KAAK,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;AACzC,sBAAc,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;OACnC,MAAM;AACL,sBAAc,GAAG,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;OAC9C;KACF;;AAED,oCA1CK,oBAAoB,CA0CJ,CAAC,CAAC,CAAC;AACxB,kBAAc,CAAC,KAAK,EAAE,CAAC;;AAEvB,QAAI,MAAM,CAAC,kBAAkB,EAAE;AAC7B,qBA7CG,aAAa,CA6CF,cAAc,EAAE,MAAM,CAAC,kBAAkB,CAAC,CAAC;KAC1D;GACF,MAAM;AACL,QAAI,OAAO,KAAK,EAAE,EAAE;AAClB,UAAI,cAAc,CAAC,OAAO,KAAK,OAAO,EAAE;AACtC,sBAAc,GAAG,SAAS,CAAC;AAC3B,iBAAS,CAAC,KAAK,EAAE,CAAC;OACnB;;AAED,UAAI,QAAQ,KAAK,CAAC,CAAC,EAAE;;AAEnB,sBAAc,GAAG,SAAS,CAAC;OAC5B,MAAM;;AAEL,sBAAc,GAAG,SAAS,CAAC;OAC5B;KACF,MAAM,IAAI,OAAO,KAAK,EAAE,IAAI,MAAM,CAAC,cAAc,KAAK,IAAI,EAAE;AAC3D,oBAAc,GAAG,aAAa,CAAC;AAC/B,sCAhEyB,SAAS,CAgExB,cAAc,EAAE,CAAC,CAAC,CAAC;KAC9B,MAAM;;AAEL,oBAAc,GAAG,SAAS,CAAC;KAC5B;GACF;CACF,CAAC;;qBAEa,aAAa;;;;;;;;;;;;wBCxEH,SAAS;;6DACgC,cAAc;;6BACtD,kBAAkB;;;;;;;;4BAQnB,iBAAiB;;;;AAN1C,IAAI,UAAU,GAAK,cAAc,CAAC;AAClC,IAAI,YAAY,GAAG,gBAAgB,CAAC;;AAOpC,IAAI,oBAAoB,GAAG,gCAAW;AACpC,MAAI,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC9C,WAAS,CAAC,SAAS,4BAAe,CAAC;;;AAGnC,SAAO,SAAS,CAAC,UAAU,EAAE;AAC3B,YAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;GACjD;CACF,CAAC;;;;;AAKF,IAAI,QAAQ;;;;;;;;;;GAAG,YAAW;AACxB,MAAI,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;;AAEhD,MAAI,CAAC,MAAM,EAAE;AACX,wBAAoB,EAAE,CAAC;AACvB,UAAM,GAAG,QAAQ,EAAE,CAAC;GACrB;;AAED,SAAO,MAAM,CAAC;CACf,CAAA,CAAC;;;;;AAKF,IAAI,QAAQ,GAAG,oBAAW;AACxB,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;AACxB,MAAI,MAAM,EAAE;AACV,WAAO,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;GACtC;CACF,CAAC;;;;;AAKF,IAAI,UAAU,GAAG,sBAAW;AAC1B,SAAO,QAAQ,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;CAC7C,CAAC;;;;;AAKF,IAAI,aAAa,GAAG,uBAAS,OAAO,EAAE,OAAO,EAAE;AAC7C,MAAI,QAAQ,GAAG,UAzDR,QAAQ,CAyDS,OAAO,CAAC,CAAC;AACjC,SAAO,CAAC,KAAK,CAAC,SAAS,GAAG,eAAe,GAAG,QAAQ,GAAG,6CAA6C,CAAC;CACtG,CAAC;;;;;AAKF,IAAI,SAAS,GAAG,mBAAS,QAAQ,EAAE;AACjC,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;AACxB,iDAjEkC,MAAM,CAiEjC,UAAU,EAAE,EAAE,EAAE,CAAC,CAAC;AACzB,iDAlE0C,IAAI,CAkEzC,MAAM,CAAC,CAAC;AACb,iDAnEgD,QAAQ,CAmE/C,MAAM,EAAE,gBAAgB,CAAC,CAAC;AACnC,iDApEO,WAAW,CAoEN,MAAM,EAAE,gBAAgB,CAAC,CAAC;;AAEtC,QAAM,CAAC,qBAAqB,GAAG,QAAQ,CAAC,aAAa,CAAC;AACtD,MAAI,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;AACvD,WAAS,CAAC,KAAK,EAAE,CAAC;;AAElB,YAAU,CAAC,YAAY;AACrB,mDA3E8C,QAAQ,CA2E7C,MAAM,EAAE,SAAS,CAAC,CAAC;GAC7B,EAAE,GAAG,CAAC,CAAC;;AAER,MAAI,KAAK,GAAG,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;;AAE9C,MAAI,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,EAAE,EAAE;AACpC,QAAI,aAAa,GAAG,QAAQ,CAAC;AAC7B,UAAM,CAAC,OAAO,GAAG,UAAU,CAAC,YAAW;AACrC,UAAI,kBAAkB,GAAI,CAAC,aAAa,IAAI,IAAI,CAAA,IAAK,MAAM,CAAC,YAAY,CAAC,wBAAwB,CAAC,KAAK,MAAM,AAAC,CAAC;AAC/G,UAAI,kBAAkB,EAAE;AACtB,qBAAa,CAAC,IAAI,CAAC,CAAC;OACrB,MACI;AACH,kBAAU,CAAC,KAAK,EAAE,CAAC;OACpB;KACF,EAAE,KAAK,CAAC,CAAC;GACX;CACF,CAAC;;;;;;AAMF,IAAI,UAAU,GAAG,sBAAW;AAC1B,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;AACxB,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;;AAExB,iDAtGO,WAAW,CAsGN,MAAM,EAAE,YAAY,CAAC,CAAC;AAClC,QAAM,CAAC,KAAK,GAAG,2BAAc,UAAU,CAAC;AACxC,QAAM,CAAC,YAAY,CAAC,MAAM,EAAE,2BAAc,SAAS,CAAC,CAAC;AACrD,QAAM,CAAC,YAAY,CAAC,aAAa,EAAE,2BAAc,gBAAgB,CAAC,CAAC;;AAEnE,iBAAe,EAAE,CAAC;CACnB,CAAC;;AAGF,IAAI,eAAe,GAAG,yBAAS,KAAK,EAAE;;AAEpC,MAAI,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,EAAE;AACjC,WAAO,KAAK,CAAC;GACd;;AAED,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;;AAExB,MAAI,UAAU,GAAG,MAAM,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;AACzD,iDAxHO,WAAW,CAwHN,UAAU,EAAE,MAAM,CAAC,CAAC;;AAEhC,MAAI,eAAe,GAAG,MAAM,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;AAClE,iDA3HO,WAAW,CA2HN,eAAe,EAAE,MAAM,CAAC,CAAC;CACtC,CAAC;;;;;AAMF,IAAI,mBAAmB,GAAG,+BAAW;AACnC,MAAI,MAAM,GAAG,QAAQ,EAAE,CAAC;AACxB,QAAM,CAAC,KAAK,CAAC,SAAS,GAAG,+CApIL,YAAY,CAoIM,QAAQ,EAAE,CAAC,CAAC;CACnD,CAAC;;QAIA,oBAAoB,GAApB,oBAAoB;QACpB,QAAQ,GAAR,QAAQ;QACR,UAAU,GAAV,UAAU;QACV,QAAQ,GAAR,QAAQ;QACR,aAAa,GAAb,aAAa;QACb,SAAS,GAAT,SAAS;QACT,UAAU,GAAV,UAAU;QACV,eAAe,GAAf,eAAe;QACf,mBAAmB,GAAnB,mBAAmB;;;;;;;;AClJrB,IAAI,YAAY;;;AAGd;;;6BAG2B;;;kMAQlB;;;6HAMA;;;uCAG8B;;;+NAS9B,4CAEgC;;;4JAQ3B;;;4GAML;;;4KAMA;;;QAGD,CAAC;;qBAEI,YAAY;;;;;;;;;;qBCvDpB,SAAS;;+CAMT,mBAAmB;;8EAMnB,cAAc;;AAhBrB,IAAI,UAAU,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;;;;;AAsB5E,IAAI,aAAa,GAAG,uBAAS,MAAM,EAAE;AACnC,MAAI,KAAK,GAAG,iCAhBZ,QAAQ,EAgBc,CAAC;;AAEvB,MAAI,MAAM,GAAG,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;AACvC,MAAI,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;AACrC,MAAI,UAAU,GAAG,KAAK,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;AACtD,MAAI,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;;;;;AAKxD,QAAM,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,GAAG,gEAnBhD,UAAU,CAmBiD,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;;;;AAKlG,OAAK,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,GAAG,gEAxB9C,UAAU,CAwB+C,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AACrG,MAAI,MAAM,CAAC,IAAI,EAAE,gEAxBV,IAAI,CAwBW,KAAK,CAAC,CAAC;;;;;AAK7B,MAAI,MAAM,CAAC,WAAW,EAAE;AACtB,oEAhCQ,QAAQ,CAgCP,KAAK,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;AACpC,SAAK,CAAC,YAAY,CAAC,mBAAmB,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;GAC7D,MAAM;;AAEL,QAAI,WAAW,GAAG,KAAK,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;AAC1D,oEArCkB,WAAW,CAqCjB,KAAK,EAAE,WAAW,CAAC,CAAC;AAChC,SAAK,CAAC,YAAY,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC;GAC7C;;;;;AAKD,kEA1CoB,IAAI,CA0CnB,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,CAAC;;AAEzC,MAAI,MAAM,CAAC,IAAI,IAAI,CAAC,OAxDpB,KAAK,EAwDsB,EAAE;;;AAE3B,UAAI,SAAS,GAAG,KAAK,CAAC;;AAEtB,WAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AAC1C,YAAI,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,EAAE;AACjC,mBAAS,GAAG,IAAI,CAAC;AACjB,gBAAM;SACP;OACF;;AAED,UAAI,CAAC,SAAS,EAAE;AACd,cAAM,CAAC,sBAAsB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AAC7C;aAAO,KAAK;UAAC;OACd;;AAED,UAAI,cAAc,GAAG,CAAC,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;AAC7D,UAAI,KAAK,YAAA,CAAC;;AAEV,UAAI,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;AAC9C,aAAK,GAAG,KAAK,CAAC,aAAa,CAAC,WAAW,GAAG,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;AAC/D,wEAjEG,IAAI,CAiEF,KAAK,CAAC,CAAC;OACb;;AAED,UAAI,MAAM,GAAG,iCA3Ef,QAAQ,EA2EiB,CAAC;;;AAGxB,cAAQ,MAAM,CAAC,IAAI;;AAEjB,aAAK,SAAS;AACZ,0EA5EI,QAAQ,CA4EH,KAAK,EAAE,SAAS,CAAC,CAAC;AAC3B,0EA7EI,QAAQ,CA6EH,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,mBAAmB,CAAC,CAAC;AAC9D,0EA9EI,QAAQ,CA8EH,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,oBAAoB,CAAC,CAAC;AAChE,gBAAM;;AAAA,AAER,aAAK,OAAO;AACV,0EAlFI,QAAQ,CAkFH,KAAK,EAAE,kBAAkB,CAAC,CAAC;AACpC,0EAnFI,QAAQ,CAmFH,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,EAAE,cAAc,CAAC,CAAC;AAC5D,gBAAM;;AAAA,AAER,aAAK,SAAS;AACZ,0EAvFI,QAAQ,CAuFH,KAAK,EAAE,cAAc,CAAC,CAAC;AAChC,0EAxFI,QAAQ,CAwFH,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,iBAAiB,CAAC,CAAC;AAC7D,0EAzFI,QAAQ,CAyFH,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,iBAAiB,CAAC,CAAC;AAC5D,gBAAM;;AAAA,AAER,aAAK,OAAO,CAAC;AACb,aAAK,QAAQ;AACX,gBAAM,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;AAC9C,gBAAM,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC;AACjC,gBAAM,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,gBAAgB,CAAC,CAAC;AAC5D,0EAjGI,QAAQ,CAiGH,KAAK,EAAE,YAAY,CAAC,CAAC;AAC9B,oBAAU,CAAC,YAAY;AACrB,kBAAM,CAAC,KAAK,EAAE,CAAC;AACf,kBAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;WACxD,EAAE,GAAG,CAAC,CAAC;AACR,gBAAM;AAAA,OACT;;;;;;GACF;;;;;AAKD,MAAI,MAAM,CAAC,QAAQ,EAAE;AACnB,QAAI,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;;AAE5D,eAAW,CAAC,KAAK,CAAC,eAAe,GAAG,MAAM,GAAG,MAAM,CAAC,QAAQ,GAAG,GAAG,CAAC;AACnE,oEA/GK,IAAI,CA+GJ,WAAW,CAAC,CAAC;;AAElB,QAAI,SAAS,GAAG,EAAE,CAAC;AACnB,QAAI,UAAU,GAAG,EAAE,CAAC;;AAEpB,QAAI,MAAM,CAAC,SAAS,EAAE;AACpB,UAAI,UAAU,GAAG,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AACxD,UAAI,QAAQ,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;AAC7B,UAAI,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;;AAE9B,UAAI,CAAC,QAAQ,IAAI,CAAC,SAAS,EAAE;AAC3B,cAAM,CAAC,kEAAkE,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;OAC/F,MAAM;AACL,iBAAS,GAAG,QAAQ,CAAC;AACrB,kBAAU,GAAG,SAAS,CAAC;OACxB;KACF;;AAED,eAAW,CAAC,YAAY,CAAC,OAAO,EAAE,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,QAAQ,GAAG,SAAS,GAAG,aAAa,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC;GACjI;;;;;AAKD,OAAK,CAAC,YAAY,CAAC,wBAAwB,EAAE,MAAM,CAAC,gBAAgB,CAAC,CAAC;AACtE,MAAI,MAAM,CAAC,gBAAgB,EAAE;AAC3B,cAAU,CAAC,KAAK,CAAC,OAAO,GAAG,cAAc,CAAC;GAC3C,MAAM;AACL,oEA3IkB,IAAI,CA2IjB,UAAU,CAAC,CAAC;GAClB;;;;;AAKD,OAAK,CAAC,YAAY,CAAC,yBAAyB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;AACxE,MAAI,MAAM,CAAC,iBAAiB,EAAE;AAC5B,eAAW,CAAC,KAAK,CAAC,OAAO,GAAG,cAAc,CAAC;GAC5C,MAAM;AACL,oEArJkB,IAAI,CAqJjB,WAAW,CAAC,CAAC;GACnB;;;;;AAKD,MAAI,MAAM,CAAC,gBAAgB,EAAE;AAC3B,cAAU,CAAC,SAAS,GAAG,gEA7JzB,UAAU,CA6J0B,MAAM,CAAC,gBAAgB,CAAC,CAAC;GAC5D;AACD,MAAI,MAAM,CAAC,iBAAiB,EAAE;AAC5B,eAAW,CAAC,SAAS,GAAG,gEAhK1B,UAAU,CAgK2B,MAAM,CAAC,iBAAiB,CAAC,CAAC;GAC9D;;;;;AAKD,MAAI,MAAM,CAAC,kBAAkB,EAAE;;AAE7B,eAAW,CAAC,KAAK,CAAC,eAAe,GAAG,MAAM,CAAC,kBAAkB,CAAC;;;AAG9D,qCAhLF,aAAa,CAgLG,WAAW,EAAE,MAAM,CAAC,kBAAkB,CAAC,CAAC;GACvD;;;;;AAKD,OAAK,CAAC,YAAY,CAAC,0BAA0B,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;;;;;AAKzE,MAAI,eAAe,GAAG,MAAM,CAAC,YAAY,GAAG,IAAI,GAAG,KAAK,CAAC;AACzD,OAAK,CAAC,YAAY,CAAC,wBAAwB,EAAE,eAAe,CAAC,CAAC;;;;;AAK9D,MAAI,CAAC,MAAM,CAAC,SAAS,EAAE;AACrB,SAAK,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAC;GAC9C,MAAM,IAAI,OAAO,MAAM,CAAC,SAAS,KAAK,QAAQ,EAAE;AAC/C,SAAK,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;GACxD,MAAM;AACL,SAAK,CAAC,YAAY,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;GAC7C;;;;;AAKD,OAAK,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;CAChD,CAAC;;qBAEa,aAAa;;;;;;;;;;;;ACrN5B,IAAI,MAAM,GAAG,gBAAS,CAAC,EAAE,CAAC,EAAE;AAC1B,OAAK,IAAI,GAAG,IAAI,CAAC,EAAE;AACjB,QAAI,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;AACzB,OAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;KACjB;GACF;AACD,SAAO,CAAC,CAAC;CACV,CAAC;;;;;AAKF,IAAI,QAAQ,GAAG,kBAAS,GAAG,EAAE;AAC3B,MAAI,MAAM,GAAG,2CAA2C,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACnE,SAAO,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC;CAClH,CAAC;;;;;AAKF,IAAI,KAAK,GAAG,iBAAW;AACrB,SAAQ,MAAM,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAE;CACzD,CAAC;;;;;AAKF,IAAI,MAAM,GAAG,gBAAS,MAAM,EAAE;AAC5B,MAAI,MAAM,CAAC,OAAO,EAAE;;AAElB,UAAM,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,GAAG,MAAM,CAAC,CAAC;GAC7C;CACF,CAAC;;;;;;AAMF,IAAI,cAAc,GAAG,wBAAS,GAAG,EAAE,GAAG,EAAE;;AAEtC,KAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;AAC7C,MAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;AAClB,OAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;GAC3D;AACD,KAAG,GAAG,GAAG,IAAI,CAAC,CAAC;;;AAGf,MAAI,GAAG,GAAG,GAAG,CAAC;AACd,MAAI,CAAC,CAAC;AACN,MAAI,CAAC,CAAC;;AAEN,OAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;AACtB,KAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AACvC,KAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;AACrE,OAAG,IAAI,CAAC,IAAI,GAAG,CAAC,CAAA,CAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;GACpC;;AAED,SAAO,GAAG,CAAC;CACZ,CAAC;;QAIA,MAAM,GAAN,MAAM;QACN,QAAQ,GAAR,QAAQ;QACR,KAAK,GAAL,KAAK;QACL,MAAM,GAAN,MAAM;QACN,cAAc,GAAd,cAAc","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// SweetAlert\n// 2014-2015 (c) - Tristan Edwards\n// github.com/t4t5/sweetalert\n\n/*\n * jQuery-like functions for manipulating the DOM\n */\nimport {\n  hasClass, addClass, removeClass, \n  escapeHtml, \n  _show, show, _hide, hide, \n  isDescendant, \n  getTopMargin,\n  fadeIn, fadeOut,\n  fireClick,\n  stopEventPropagation\n} from './modules/handle-dom';\n\n/*\n * Handy utilities\n */\nimport {\n  extend,\n  hexToRgb,\n  isIE8,\n  logStr,\n  colorLuminance\n} from './modules/utils';\n\n/*\n *  Handle sweetAlert's DOM elements\n */\nimport {\n  sweetAlertInitialize,\n  getModal,\n  getOverlay,\n  getInput,\n  setFocusStyle,\n  openModal,\n  resetInput,\n  fixVerticalPosition\n} from './modules/handle-swal-dom';\n\n\n// Handle button events and keyboard events\nimport { handleButton, handleConfirm, handleCancel } from './modules/handle-click';\nimport handleKeyDown from './modules/handle-key';\n\n\n// Default values\nimport defaultParams from './modules/default-params';\nimport setParameters from './modules/set-params';\n\n/*\n * Remember state in cases where opening and handling a modal will fiddle with it.\n * (We also use window.previousActiveElement as a global variable)\n */\nvar previousWindowKeyDown;\nvar lastFocusedButton;\n\n\n/*\n * Global sweetAlert function\n * (this is what the user calls)\n */\nvar sweetAlert, swal;\n\nsweetAlert = swal = function() {\n  var customizations = arguments[0];\n\n  addClass(document.body, 'stop-scrolling');\n  resetInput();\n\n  /*\n   * Use argument if defined or default value from params object otherwise.\n   * Supports the case where a default value is boolean true and should be\n   * overridden by a corresponding explicit argument which is boolean false.\n   */\n  function argumentOrDefault(key) {\n    var args = customizations;\n    return (args[key] === undefined) ?  defaultParams[key] : args[key];\n  }\n\n  if (customizations === undefined) {\n    logStr('SweetAlert expects at least 1 attribute!');\n    return false;\n  }\n\n  var params = extend({}, defaultParams);\n\n  switch (typeof customizations) {\n\n    // Ex: swal(\"Hello\", \"Just testing\", \"info\");\n    case 'string':\n      params.title = customizations;\n      params.text  = arguments[1] || '';\n      params.type  = arguments[2] || '';\n      break;\n\n    // Ex: swal({ title:\"Hello\", text: \"Just testing\", type: \"info\" });\n    case 'object':\n      if (customizations.title === undefined) {\n        logStr('Missing \"title\" argument!');\n        return false;\n      }\n\n      params.title = customizations.title;\n\n      for (let customName in defaultParams) {\n        params[customName] = argumentOrDefault(customName);\n      }\n\n      // Show \"Confirm\" instead of \"OK\" if cancel button is visible\n      params.confirmButtonText = params.showCancelButton ? 'Confirm' : defaultParams.confirmButtonText;\n      params.confirmButtonText = argumentOrDefault('confirmButtonText');\n\n      // Callback function when clicking on \"OK\"/\"Cancel\"\n      params.doneFunction = arguments[1] || null;\n\n      break;\n\n    default:\n      logStr('Unexpected type of argument! Expected \"string\" or \"object\", got ' + typeof customizations);\n      return false;\n\n  }\n\n  setParameters(params);\n  fixVerticalPosition();\n  openModal(arguments[1]);\n\n  // Modal interactions\n  var modal = getModal();\n\n\n  /* \n   * Make sure all modal buttons respond to all events\n   */\n  var $buttons = modal.querySelectorAll('button');\n  var buttonEvents = ['onclick', 'onmouseover', 'onmouseout', 'onmousedown', 'onmouseup', 'onfocus'];\n  var onButtonEvent = (e) => handleButton(e, params, modal);\n\n  for (let btnIndex = 0; btnIndex < $buttons.length; btnIndex++) {\n    for (let evtIndex = 0; evtIndex < buttonEvents.length; evtIndex++) {\n      let btnEvt = buttonEvents[evtIndex];\n      $buttons[btnIndex][btnEvt] = onButtonEvent;\n    }\n  }\n\n  // Clicking outside the modal dismisses it (if allowed by user)\n  getOverlay().onclick = onButtonEvent;\n\n  previousWindowKeyDown = window.onkeydown;\n\n  var onKeyEvent = (e) => handleKeyDown(e, params, modal);\n  window.onkeydown = onKeyEvent;\n\n  window.onfocus = function () {\n    // When the user has focused away and focused back from the whole window.\n    setTimeout(function () {\n      // Put in a timeout to jump out of the event sequence.\n      // Calling focus() in the event sequence confuses things.\n      if (lastFocusedButton !== undefined) {\n        lastFocusedButton.focus();\n        lastFocusedButton = undefined;\n      }\n    }, 0);\n  };\n};\n\n\n\n/*\n * Set default params for each popup\n * @param {Object} userParams\n */\nsweetAlert.setDefaults = swal.setDefaults = function(userParams) {\n  if (!userParams) {\n    throw new Error('userParams is required');\n  }\n  if (typeof userParams !== 'object') {\n    throw new Error('userParams has to be a object');\n  }\n\n  extend(defaultParams, userParams);\n};\n\n\n/*\n * Animation when closing modal\n */\nsweetAlert.close = swal.close = function() {\n  var modal = getModal();\n\n  fadeOut(getOverlay(), 5);\n  fadeOut(modal, 5);\n  removeClass(modal, 'showSweetAlert');\n  addClass(modal, 'hideSweetAlert');\n  removeClass(modal, 'visible');\n\n  /*\n   * Reset icon animations\n   */\n  var $successIcon = modal.querySelector('.sa-icon.sa-success');\n  removeClass($successIcon, 'animate');\n  removeClass($successIcon.querySelector('.sa-tip'), 'animateSuccessTip');\n  removeClass($successIcon.querySelector('.sa-long'), 'animateSuccessLong');\n\n  var $errorIcon = modal.querySelector('.sa-icon.sa-error');\n  removeClass($errorIcon, 'animateErrorIcon');\n  removeClass($errorIcon.querySelector('.sa-x-mark'), 'animateXMark');\n\n  var $warningIcon = modal.querySelector('.sa-icon.sa-warning');\n  removeClass($warningIcon, 'pulseWarning');\n  removeClass($warningIcon.querySelector('.sa-body'), 'pulseWarningIns');\n  removeClass($warningIcon.querySelector('.sa-dot'), 'pulseWarningIns');\n\n  // Reset custom class (delay so that UI changes aren't visible)\n  setTimeout(function() {\n    var customClass = modal.getAttribute('data-custom-class');\n    removeClass(modal, customClass);\n  }, 300);\n\n  // Make page scrollable again\n  removeClass(document.body, 'stop-scrolling');\n\n  // Reset the page to its previous state\n  window.onkeydown = previousWindowKeyDown;\n  if (window.previousActiveElement) {\n    window.previousActiveElement.focus();\n  }\n  lastFocusedButton = undefined;\n  clearTimeout(modal.timeout);\n\n  return true;\n};\n\n\n/*\n * Validation of the input field is done by user\n * If something is wrong => call showInputError with errorMessage\n */\nsweetAlert.showInputError = swal.showInputError = function(errorMessage) {\n  var modal = getModal();\n\n  var $errorIcon = modal.querySelector('.sa-input-error');\n  addClass($errorIcon, 'show');\n\n  var $errorContainer = modal.querySelector('.sa-error-container');\n  addClass($errorContainer, 'show');\n\n  $errorContainer.querySelector('p').innerHTML = errorMessage;\n\n  modal.querySelector('input').focus();\n};\n\n\n/*\n * Reset input error DOM elements\n */\nsweetAlert.resetInputError = swal.resetInputError = function(event) {\n  // If press enter => ignore\n  if (event && event.keyCode === 13) {\n    return false;\n  }\n\n  var $modal = getModal();\n\n  var $errorIcon = $modal.querySelector('.sa-input-error');\n  removeClass($errorIcon, 'show');\n\n  var $errorContainer = $modal.querySelector('.sa-error-container');\n  removeClass($errorContainer, 'show');\n};\n\nif (typeof window !== 'undefined') {\n  // The 'handle-click' module requires\n  // that 'sweetAlert' was set as global.\n  window.sweetAlert = window.swal = sweetAlert;\n} else {\n  logStr('SweetAlert is a frontend module!');\n}\n","var defaultParams = {\n  title: '',\n  text: '',\n  type: null,\n  allowOutsideClick: false,\n  showConfirmButton: true,\n  showCancelButton: false,\n  closeOnConfirm: true,\n  closeOnCancel: true,\n  confirmButtonText: 'OK',\n  confirmButtonColor: '#AEDEF4',\n  cancelButtonText: 'Cancel',\n  imageUrl: null,\n  imageSize: null,\n  timer: null,\n  customClass: '',\n  html: false,\n  animation: true,\n  allowEscapeKey: true,\n  inputType: 'text',\n  inputPlaceholder: '',\n  inputValue: ''\n};\n\nexport default defaultParams;","import { colorLuminance } from './utils';\nimport { getModal } from './handle-swal-dom';\nimport { hasClass, isDescendant } from './handle-dom';\n\n\n/*\n * User clicked on \"Confirm\"/\"OK\" or \"Cancel\"\n */\nvar handleButton = function(event, params, modal) {\n  var e = event || window.event;\n  var target = e.target || e.srcElement;\n\n  var targetedConfirm = target.className.indexOf('confirm') !== -1;\n  var targetedOverlay = target.className.indexOf('sweet-overlay') !== -1;\n  var modalIsVisible  = hasClass(modal, 'visible');\n  var doneFunctionExists = (params.doneFunction && modal.getAttribute('data-has-done-function') === 'true');\n\n  // Since the user can change the background-color of the confirm button programmatically,\n  // we must calculate what the color should be on hover/active\n  var normalColor, hoverColor, activeColor;\n  if (targetedConfirm && params.confirmButtonColor) {\n    normalColor  = params.confirmButtonColor;\n    hoverColor   = colorLuminance(normalColor, -0.04);\n    activeColor  = colorLuminance(normalColor, -0.14);\n  }\n\n  function shouldSetConfirmButtonColor(color) {\n    if (targetedConfirm && params.confirmButtonColor) {\n      target.style.backgroundColor = color;\n    }\n  }\n\n  switch (e.type) {\n    case 'mouseover':\n      shouldSetConfirmButtonColor(hoverColor);\n      break;\n\n    case 'mouseout':\n      shouldSetConfirmButtonColor(normalColor);\n      break;\n\n    case 'mousedown':\n      shouldSetConfirmButtonColor(activeColor);\n      break;\n\n    case 'mouseup':\n      shouldSetConfirmButtonColor(hoverColor);\n      break;\n\n    case 'focus':\n      let $confirmButton = modal.querySelector('button.confirm');\n      let $cancelButton  = modal.querySelector('button.cancel');\n\n      if (targetedConfirm) {\n        $cancelButton.style.boxShadow = 'none';\n      } else {\n        $confirmButton.style.boxShadow = 'none';\n      }\n      break;\n\n    case 'click':\n      let clickedOnModal = (modal === target);\n      let clickedOnModalChild = isDescendant(modal, target);\n\n      // Ignore click outside if allowOutsideClick is false\n      if (!clickedOnModal && !clickedOnModalChild && modalIsVisible && !params.allowOutsideClick) {\n        break;\n      }\n\n      if (targetedConfirm && doneFunctionExists && modalIsVisible) {\n        handleConfirm(modal, params);\n      } else if (doneFunctionExists && modalIsVisible || targetedOverlay) {\n        handleCancel(modal, params);\n      } else if (isDescendant(modal, target) && target.tagName === 'BUTTON') {\n        sweetAlert.close();\n      }\n      break;\n  }\n};\n\n/*\n *  User clicked on \"Confirm\"/\"OK\"\n */\nvar handleConfirm = function(modal, params) {\n  var callbackValue = true;\n\n  if (hasClass(modal, 'show-input')) {\n    callbackValue = modal.querySelector('input').value;\n\n    if (!callbackValue) {\n      callbackValue = '';\n    }\n  }\n\n  params.doneFunction(callbackValue);\n\n  if (params.closeOnConfirm) {\n    sweetAlert.close();\n  }\n};\n\n/*\n *  User clicked on \"Cancel\"\n */\nvar handleCancel = function(modal, params) {\n  // Check if callback function expects a parameter (to track cancel actions)\n  var functionAsStr = String(params.doneFunction).replace(/\\s/g, '');\n  var functionHandlesCancel = functionAsStr.substring(0, 9) === 'function(' && functionAsStr.substring(9, 10) !== ')';\n\n  if (functionHandlesCancel) {\n    params.doneFunction(false);\n  }\n\n  if (params.closeOnCancel) {\n    sweetAlert.close();\n  }\n};\n\n\nexport default {\n  handleButton,\n  handleConfirm,\n  handleCancel\n};","var hasClass = function(elem, className) {\n  return new RegExp(' ' + className + ' ').test(' ' + elem.className + ' ');\n};\n\nvar addClass = function(elem, className) {\n  if (!hasClass(elem, className)) {\n    elem.className += ' ' + className;\n  }\n};\n\nvar removeClass = function(elem, className) {\n  var newClass = ' ' + elem.className.replace(/[\\t\\r\\n]/g, ' ') + ' ';\n  if (hasClass(elem, className)) {\n    while (newClass.indexOf(' ' + className + ' ') >= 0) {\n      newClass = newClass.replace(' ' + className + ' ', ' ');\n    }\n    elem.className = newClass.replace(/^\\s+|\\s+$/g, '');\n  }\n};\n\nvar escapeHtml = function(str) {\n  var div = document.createElement('div');\n  div.appendChild(document.createTextNode(str));\n  return div.innerHTML;\n};\n\nvar _show = function(elem) {\n  elem.style.opacity = '';\n  elem.style.display = 'block';\n};\n\nvar show = function(elems) {\n  if (elems && !elems.length) {\n    return _show(elems);\n  }\n  for (var i = 0; i < elems.length; ++i) {\n    _show(elems[i]);\n  }\n};\n\nvar _hide = function(elem) {\n  elem.style.opacity = '';\n  elem.style.display = 'none';\n};\n\nvar hide = function(elems) {\n  if (elems && !elems.length) {\n    return _hide(elems);\n  }\n  for (var i = 0; i < elems.length; ++i) {\n    _hide(elems[i]);\n  }\n};\n\nvar isDescendant = function(parent, child) {\n  var node = child.parentNode;\n  while (node !== null) {\n    if (node === parent) {\n      return true;\n    }\n    node = node.parentNode;\n  }\n  return false;\n};\n\nvar getTopMargin = function(elem) {\n  elem.style.left = '-9999px';\n  elem.style.display = 'block';\n\n  var height = elem.clientHeight,\n      padding;\n  if (typeof getComputedStyle !== \"undefined\") { // IE 8\n    padding = parseInt(getComputedStyle(elem).getPropertyValue('padding-top'), 10);\n  } else {\n    padding = parseInt(elem.currentStyle.padding);\n  }\n\n  elem.style.left = '';\n  elem.style.display = 'none';\n  return ('-' + parseInt((height + padding) / 2) + 'px');\n};\n\nvar fadeIn = function(elem, interval) {\n  if (+elem.style.opacity < 1) {\n    interval = interval || 16;\n    elem.style.opacity = 0;\n    elem.style.display = 'block';\n    var last = +new Date();\n    var tick = function() {\n      elem.style.opacity = +elem.style.opacity + (new Date() - last) / 100;\n      last = +new Date();\n\n      if (+elem.style.opacity < 1) {\n        setTimeout(tick, interval);\n      }\n    };\n    tick();\n  }\n  elem.style.display = 'block'; //fallback IE8\n};\n\nvar fadeOut = function(elem, interval) {\n  interval = interval || 16;\n  elem.style.opacity = 1;\n  var last = +new Date();\n  var tick = function() {\n    elem.style.opacity = +elem.style.opacity - (new Date() - last) / 100;\n    last = +new Date();\n\n    if (+elem.style.opacity > 0) {\n      setTimeout(tick, interval);\n    } else {\n      elem.style.display = 'none';\n    }\n  };\n  tick();\n};\n\nvar fireClick = function(node) {\n  // Taken from http://www.nonobtrusive.com/2011/11/29/programatically-fire-crossbrowser-click-event-with-javascript/\n  // Then fixed for today's Chrome browser.\n  if (typeof MouseEvent === 'function') {\n    // Up-to-date approach\n    var mevt = new MouseEvent('click', {\n      view: window,\n      bubbles: false,\n      cancelable: true\n    });\n    node.dispatchEvent(mevt);\n  } else if ( document.createEvent ) {\n    // Fallback\n    var evt = document.createEvent('MouseEvents');\n    evt.initEvent('click', false, false);\n    node.dispatchEvent(evt);\n  } else if (document.createEventObject) {\n    node.fireEvent('onclick') ;\n  } else if (typeof node.onclick === 'function' ) {\n    node.onclick();\n  }\n};\n\nvar stopEventPropagation = function(e) {\n  // In particular, make sure the space bar doesn't scroll the main window.\n  if (typeof e.stopPropagation === 'function') {\n    e.stopPropagation();\n    e.preventDefault();\n  } else if (window.event && window.event.hasOwnProperty('cancelBubble')) {\n    window.event.cancelBubble = true;\n  }\n};\n\nexport { \n  hasClass, addClass, removeClass, \n  escapeHtml, \n  _show, show, _hide, hide, \n  isDescendant, \n  getTopMargin,\n  fadeIn, fadeOut,\n  fireClick,\n  stopEventPropagation\n};\n","import { stopEventPropagation, fireClick } from './handle-dom';\nimport { setFocusStyle } from './handle-swal-dom';\n\n\nvar handleKeyDown = function(event, params, modal) {\n  var e = event || window.event;\n  var keyCode = e.keyCode || e.which;\n\n  var $okButton     = modal.querySelector('button.confirm');\n  var $cancelButton = modal.querySelector('button.cancel');\n  var $modalButtons = modal.querySelectorAll('button[tabindex]');\n\n\n  if ([9, 13, 32, 27].indexOf(keyCode) === -1) {\n    // Don't do work on keys we don't care about.\n    return;\n  }\n\n  var $targetElement = e.target || e.srcElement;\n\n  var btnIndex = -1; // Find the button - note, this is a nodelist, not an array.\n  for (var i = 0; i < $modalButtons.length; i++) {\n    if ($targetElement === $modalButtons[i]) {\n      btnIndex = i;\n      break;\n    }\n  }\n\n  if (keyCode === 9) {\n    // TAB\n    if (btnIndex === -1) {\n      // No button focused. Jump to the confirm button.\n      $targetElement = $okButton;\n    } else {\n      // Cycle to the next button\n      if (btnIndex === $modalButtons.length - 1) {\n        $targetElement = $modalButtons[0];\n      } else {\n        $targetElement = $modalButtons[btnIndex + 1];\n      }\n    }\n\n    stopEventPropagation(e);\n    $targetElement.focus();\n\n    if (params.confirmButtonColor) {\n      setFocusStyle($targetElement, params.confirmButtonColor);\n    }\n  } else {\n    if (keyCode === 13) {\n      if ($targetElement.tagName === 'INPUT') {\n        $targetElement = $okButton;\n        $okButton.focus();\n      }\n\n      if (btnIndex === -1) {\n        // ENTER/SPACE clicked outside of a button.\n        $targetElement = $okButton;\n      } else {\n        // Do nothing - let the browser handle it.\n        $targetElement = undefined;\n      }\n    } else if (keyCode === 27 && params.allowEscapeKey === true) {\n      $targetElement = $cancelButton;\n      fireClick($targetElement, e);\n    } else {\n      // Fallback - let the browser handle it.\n      $targetElement = undefined;\n    }\n  }\n};\n\nexport default handleKeyDown;\n","import { hexToRgb } from './utils';\nimport { removeClass, getTopMargin, fadeIn, show, addClass } from './handle-dom';\nimport defaultParams from './default-params';\n\nvar modalClass   = '.sweet-alert';\nvar overlayClass = '.sweet-overlay';\n\n/*\n * Add modal + overlay to DOM\n */\nimport injectedHTML from './injected-html';\n\nvar sweetAlertInitialize = function() {\n  var sweetWrap = document.createElement('div');\n  sweetWrap.innerHTML = injectedHTML;\n\n  // Append elements to body\n  while (sweetWrap.firstChild) {\n    document.body.appendChild(sweetWrap.firstChild);\n  }\n};\n\n/*\n * Get DOM element of modal\n */\nvar getModal = function() {\n  var $modal = document.querySelector(modalClass);\n\n  if (!$modal) {\n    sweetAlertInitialize();\n    $modal = getModal();\n  }\n\n  return $modal;\n};\n\n/*\n * Get DOM element of input (in modal)\n */\nvar getInput = function() {\n  var $modal = getModal();\n  if ($modal) {\n    return $modal.querySelector('input');\n  }\n};\n\n/*\n * Get DOM element of overlay\n */\nvar getOverlay = function() {\n  return document.querySelector(overlayClass);\n};\n\n/*\n * Add box-shadow style to button (depending on its chosen bg-color)\n */\nvar setFocusStyle = function($button, bgColor) {\n  var rgbColor = hexToRgb(bgColor);\n  $button.style.boxShadow = '0 0 2px rgba(' + rgbColor + ', 0.8), inset 0 0 0 1px rgba(0, 0, 0, 0.05)';\n};\n\n/*\n * Animation when opening modal\n */\nvar openModal = function(callback) {\n  var $modal = getModal();\n  fadeIn(getOverlay(), 10);\n  show($modal);\n  addClass($modal, 'showSweetAlert');\n  removeClass($modal, 'hideSweetAlert');\n\n  window.previousActiveElement = document.activeElement;\n  var $okButton = $modal.querySelector('button.confirm');\n  $okButton.focus();\n\n  setTimeout(function () {\n    addClass($modal, 'visible');\n  }, 500);\n\n  var timer = $modal.getAttribute('data-timer');\n\n  if (timer !== 'null' && timer !== '') {\n    var timerCallback = callback;\n    $modal.timeout = setTimeout(function() {\n      var doneFunctionExists = ((timerCallback || null) && $modal.getAttribute('data-has-done-function') === 'true');\n      if (doneFunctionExists) { \n        timerCallback(null);\n      }\n      else {\n        sweetAlert.close();\n      }\n    }, timer);\n  }\n};\n\n/*\n * Reset the styling of the input\n * (for example if errors have been shown)\n */\nvar resetInput = function() {\n  var $modal = getModal();\n  var $input = getInput();\n\n  removeClass($modal, 'show-input');\n  $input.value = defaultParams.inputValue;\n  $input.setAttribute('type', defaultParams.inputType);\n  $input.setAttribute('placeholder', defaultParams.inputPlaceholder);\n\n  resetInputError();\n};\n\n\nvar resetInputError = function(event) {\n  // If press enter => ignore\n  if (event && event.keyCode === 13) {\n    return false;\n  }\n\n  var $modal = getModal();\n\n  var $errorIcon = $modal.querySelector('.sa-input-error');\n  removeClass($errorIcon, 'show');\n\n  var $errorContainer = $modal.querySelector('.sa-error-container');\n  removeClass($errorContainer, 'show');\n};\n\n\n/*\n * Set \"margin-top\"-property on modal based on its computed height\n */\nvar fixVerticalPosition = function() {\n  var $modal = getModal();\n  $modal.style.marginTop = getTopMargin(getModal());\n};\n\n\nexport { \n  sweetAlertInitialize,\n  getModal,\n  getOverlay,\n  getInput,\n  setFocusStyle,\n  openModal,\n  resetInput,\n  resetInputError,\n  fixVerticalPosition\n};\n","var injectedHTML = \n\n  // Dark overlay\n  `<div class=\"sweet-overlay\" tabIndex=\"-1\"></div>` +\n\n  // Modal\n  `<div class=\"sweet-alert\">` +\n\n    // Error icon\n    `<div class=\"sa-icon sa-error\">\n      <span class=\"sa-x-mark\">\n        <span class=\"sa-line sa-left\"></span>\n        <span class=\"sa-line sa-right\"></span>\n      </span>\n    </div>` +\n\n    // Warning icon\n    `<div class=\"sa-icon sa-warning\">\n      <span class=\"sa-body\"></span>\n      <span class=\"sa-dot\"></span>\n    </div>` +\n\n    // Info icon\n    `<div class=\"sa-icon sa-info\"></div>` +\n\n    // Success icon\n    `<div class=\"sa-icon sa-success\">\n      <span class=\"sa-line sa-tip\"></span>\n      <span class=\"sa-line sa-long\"></span>\n\n      <div class=\"sa-placeholder\"></div>\n      <div class=\"sa-fix\"></div>\n    </div>` +\n\n    `<div class=\"sa-icon sa-custom\"></div>` +\n\n    // Title, text and input\n    `<h2>Title</h2>\n    <p>Text</p>\n    <fieldset>\n      <input type=\"text\" tabIndex=\"3\" />\n      <div class=\"sa-input-error\"></div>\n    </fieldset>` +\n\n    // Input errors\n    `<div class=\"sa-error-container\">\n      <div class=\"icon\">!</div>\n      <p>Not valid!</p>\n    </div>` +\n\n    // Cancel and confirm buttons\n    `<div class=\"sa-button-container\">\n      <button class=\"cancel\" tabIndex=\"2\">Cancel</button>\n      <button class=\"confirm\" tabIndex=\"1\">OK</button>\n    </div>` +\n\n  // End of modal\n  `</div>`;\n\nexport default injectedHTML;","var alertTypes = ['error', 'warning', 'info', 'success', 'input', 'prompt'];\n\nimport {\n  isIE8\n} from './utils';\n\nimport {\n  getModal,\n  getInput,\n  setFocusStyle\n} from './handle-swal-dom';\n\nimport {\n  hasClass, addClass, removeClass, \n  escapeHtml, \n  _show, show, _hide, hide\n} from './handle-dom';\n\n\n/*\n * Set type, text and actions on modal\n */\nvar setParameters = function(params) {\n  var modal = getModal();\n\n  var $title = modal.querySelector('h2');\n  var $text = modal.querySelector('p');\n  var $cancelBtn = modal.querySelector('button.cancel');\n  var $confirmBtn = modal.querySelector('button.confirm');\n\n  /*\n   * Title\n   */\n  $title.innerHTML = params.html ? params.title : escapeHtml(params.title).split('\\n').join('<br>');\n\n  /*\n   * Text\n   */\n  $text.innerHTML = params.html ? params.text : escapeHtml(params.text || '').split('\\n').join('<br>');\n  if (params.text) show($text);\n\n  /*\n   * Custom class\n   */\n  if (params.customClass) {\n    addClass(modal, params.customClass);\n    modal.setAttribute('data-custom-class', params.customClass);\n  } else {\n    // Find previously set classes and remove them\n    let customClass = modal.getAttribute('data-custom-class');\n    removeClass(modal, customClass);\n    modal.setAttribute('data-custom-class', '');\n  }\n\n  /*\n   * Icon\n   */\n  hide(modal.querySelectorAll('.sa-icon'));\n\n  if (params.type && !isIE8()) {\n\n    let validType = false;\n\n    for (let i = 0; i < alertTypes.length; i++) {\n      if (params.type === alertTypes[i]) {\n        validType = true;\n        break;\n      }\n    }\n\n    if (!validType) {\n      logStr('Unknown alert type: ' + params.type);\n      return false;\n    }\n\n    let typesWithIcons = ['success', 'error', 'warning', 'info'];\n    let $icon;\n\n    if (typesWithIcons.indexOf(params.type) !== -1) {\n      $icon = modal.querySelector('.sa-icon.' + 'sa-' + params.type);\n      show($icon);\n    }\n\n    let $input = getInput();\n\n    // Animate icon\n    switch (params.type) {\n\n      case 'success':\n        addClass($icon, 'animate');\n        addClass($icon.querySelector('.sa-tip'), 'animateSuccessTip');\n        addClass($icon.querySelector('.sa-long'), 'animateSuccessLong');\n        break;\n\n      case 'error':\n        addClass($icon, 'animateErrorIcon');\n        addClass($icon.querySelector('.sa-x-mark'), 'animateXMark');\n        break;\n\n      case 'warning':\n        addClass($icon, 'pulseWarning');\n        addClass($icon.querySelector('.sa-body'), 'pulseWarningIns');\n        addClass($icon.querySelector('.sa-dot'), 'pulseWarningIns');\n        break;\n\n      case 'input':\n      case 'prompt':\n        $input.setAttribute('type', params.inputType);\n        $input.value = params.inputValue;\n        $input.setAttribute('placeholder', params.inputPlaceholder);\n        addClass(modal, 'show-input');\n        setTimeout(function () {\n          $input.focus();\n          $input.addEventListener('keyup', swal.resetInputError);\n        }, 400);\n        break;\n    }\n  }\n\n  /*\n   * Custom image\n   */\n  if (params.imageUrl) {\n    let $customIcon = modal.querySelector('.sa-icon.sa-custom');\n\n    $customIcon.style.backgroundImage = 'url(' + params.imageUrl + ')';\n    show($customIcon);\n\n    let _imgWidth = 80;\n    let _imgHeight = 80;\n\n    if (params.imageSize) {\n      let dimensions = params.imageSize.toString().split('x');\n      let imgWidth = dimensions[0];\n      let imgHeight = dimensions[1];\n\n      if (!imgWidth || !imgHeight) {\n        logStr('Parameter imageSize expects value with format WIDTHxHEIGHT, got ' + params.imageSize);\n      } else {\n        _imgWidth = imgWidth;\n        _imgHeight = imgHeight;\n      }\n    }\n\n    $customIcon.setAttribute('style', $customIcon.getAttribute('style') + 'width:' + _imgWidth + 'px; height:' + _imgHeight + 'px');\n  }\n\n  /*\n   * Show cancel button?\n   */\n  modal.setAttribute('data-has-cancel-button', params.showCancelButton);\n  if (params.showCancelButton) {\n    $cancelBtn.style.display = 'inline-block';\n  } else {\n    hide($cancelBtn);\n  }\n\n  /*\n   * Show confirm button?\n   */\n  modal.setAttribute('data-has-confirm-button', params.showConfirmButton);\n  if (params.showConfirmButton) {\n    $confirmBtn.style.display = 'inline-block';\n  } else {\n    hide($confirmBtn);\n  }\n\n  /*\n   * Custom text on cancel/confirm buttons\n   */\n  if (params.cancelButtonText) {\n    $cancelBtn.innerHTML = escapeHtml(params.cancelButtonText);\n  }\n  if (params.confirmButtonText) {\n    $confirmBtn.innerHTML = escapeHtml(params.confirmButtonText);\n  }\n\n  /*\n   * Custom color on confirm button\n   */\n  if (params.confirmButtonColor) {\n    // Set confirm button to selected background color\n    $confirmBtn.style.backgroundColor = params.confirmButtonColor;\n\n    // Set box-shadow to default focused button\n    setFocusStyle($confirmBtn, params.confirmButtonColor);\n  }\n\n  /*\n   * Allow outside click\n   */\n  modal.setAttribute('data-allow-outside-click', params.allowOutsideClick);\n\n  /*\n   * Callback function\n   */\n  var hasDoneFunction = params.doneFunction ? true : false;\n  modal.setAttribute('data-has-done-function', hasDoneFunction);\n\n  /*\n   * Animation\n   */\n  if (!params.animation) {\n    modal.setAttribute('data-animation', 'none');\n  } else if (typeof params.animation === 'string') {\n    modal.setAttribute('data-animation', params.animation); // Custom animation\n  } else {\n    modal.setAttribute('data-animation', 'pop');\n  }\n\n  /*\n   * Timer\n   */\n  modal.setAttribute('data-timer', params.timer);\n};\n\nexport default setParameters;\n","/*\n * Allow user to pass their own params\n */\nvar extend = function(a, b) {\n  for (var key in b) {\n    if (b.hasOwnProperty(key)) {\n      a[key] = b[key];\n    }\n  }\n  return a;\n};\n\n/*\n * Convert HEX codes to RGB values (#000000 -> rgb(0,0,0))\n */\nvar hexToRgb = function(hex) {\n  var result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n  return result ? parseInt(result[1], 16) + ', ' + parseInt(result[2], 16) + ', ' + parseInt(result[3], 16) : null;\n};\n\n/*\n * Check if the user is using Internet Explorer 8 (for fallbacks)\n */\nvar isIE8 = function() {\n  return (window.attachEvent && !window.addEventListener);\n};\n\n/*\n * IE compatible logging for developers\n */\nvar logStr = function(string) {\n  if (window.console) {\n    // IE...\n    window.console.log('SweetAlert: ' + string);\n  }\n};\n\n/*\n * Set hover, active and focus-states for buttons \n * (source: http://www.sitepoint.com/javascript-generate-lighter-darker-color)\n */\nvar colorLuminance = function(hex, lum) {\n  // Validate hex string\n  hex = String(hex).replace(/[^0-9a-f]/gi, '');\n  if (hex.length < 6) {\n    hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2];\n  }\n  lum = lum || 0;\n\n  // Convert to decimal and change luminosity\n  var rgb = '#';\n  var c;\n  var i;\n\n  for (i = 0; i < 3; i++) {\n    c = parseInt(hex.substr(i * 2, 2), 16);\n    c = Math.round(Math.min(Math.max(0, c + c * lum), 255)).toString(16);\n    rgb += ('00' + c).substr(c.length);\n  }\n\n  return rgb;\n};\n\n\nexport {\n  extend,\n  hexToRgb,\n  isIE8,\n  logStr,\n  colorLuminance\n};\n"]} + + + /* + * Use SweetAlert with RequireJS + */ + + if (typeof define === 'function' && define.amd) { + define(function () { + return sweetAlert; + }); + } else if (typeof module !== 'undefined' && module.exports) { + module.exports = sweetAlert; + } + +})(window, document); \ No newline at end of file diff --git a/src/main/webapp/bower_components/sweetalert/sweetalert.css b/src/main/webapp/bower_components/sweetalert/sweetalert.css new file mode 100644 index 0000000..4469aea --- /dev/null +++ b/src/main/webapp/bower_components/sweetalert/sweetalert.css @@ -0,0 +1,715 @@ +body.stop-scrolling { + height: 100%; + overflow: hidden; } + +.sweet-overlay { + background-color: black; + /* IE8 */ + -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)"; + /* IE8 */ + background-color: rgba(0, 0, 0, 0.4); + position: fixed; + left: 0; + right: 0; + top: 0; + bottom: 0; + display: none; + z-index: 10000; } + +.sweet-alert { + background-color: white; + font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; + width: 478px; + padding: 17px; + border-radius: 5px; + text-align: center; + position: fixed; + left: 50%; + top: 50%; + margin-left: -256px; + margin-top: -200px; + overflow: hidden; + display: none; + z-index: 99999; } + @media all and (max-width: 540px) { + .sweet-alert { + width: auto; + margin-left: 0; + margin-right: 0; + left: 15px; + right: 15px; } } + .sweet-alert h2 { + color: #575757; + font-size: 30px; + text-align: center; + font-weight: 600; + text-transform: none; + position: relative; + margin: 25px 0; + padding: 0; + line-height: 40px; + display: block; } + .sweet-alert p { + color: #797979; + font-size: 16px; + text-align: center; + font-weight: 300; + position: relative; + text-align: inherit; + float: none; + margin: 0; + padding: 0; + line-height: normal; } + .sweet-alert fieldset { + border: none; + position: relative; } + .sweet-alert .sa-error-container { + background-color: #f1f1f1; + margin-left: -17px; + margin-right: -17px; + overflow: hidden; + padding: 0 10px; + max-height: 0; + webkit-transition: padding 0.15s, max-height 0.15s; + transition: padding 0.15s, max-height 0.15s; } + .sweet-alert .sa-error-container.show { + padding: 10px 0; + max-height: 100px; + webkit-transition: padding 0.2s, max-height 0.2s; + transition: padding 0.25s, max-height 0.25s; } + .sweet-alert .sa-error-container .icon { + display: inline-block; + width: 24px; + height: 24px; + border-radius: 50%; + background-color: #ea7d7d; + color: white; + line-height: 24px; + text-align: center; + margin-right: 3px; } + .sweet-alert .sa-error-container p { + display: inline-block; } + .sweet-alert .sa-input-error { + position: absolute; + top: 29px; + right: 26px; + width: 20px; + height: 20px; + opacity: 0; + -webkit-transform: scale(0.5); + transform: scale(0.5); + -webkit-transform-origin: 50% 50%; + transform-origin: 50% 50%; + -webkit-transition: all 0.1s; + transition: all 0.1s; } + .sweet-alert .sa-input-error::before, .sweet-alert .sa-input-error::after { + content: ""; + width: 20px; + height: 6px; + background-color: #f06e57; + border-radius: 3px; + position: absolute; + top: 50%; + margin-top: -4px; + left: 50%; + margin-left: -9px; } + .sweet-alert .sa-input-error::before { + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); } + .sweet-alert .sa-input-error::after { + -webkit-transform: rotate(45deg); + transform: rotate(45deg); } + .sweet-alert .sa-input-error.show { + opacity: 1; + -webkit-transform: scale(1); + transform: scale(1); } + .sweet-alert input { + width: 100%; + box-sizing: border-box; + border-radius: 3px; + border: 1px solid #d7d7d7; + height: 43px; + margin-top: 10px; + margin-bottom: 17px; + font-size: 18px; + box-shadow: inset 0px 1px 1px rgba(0, 0, 0, 0.06); + padding: 0 12px; + display: none; + -webkit-transition: all 0.3s; + transition: all 0.3s; } + .sweet-alert input:focus { + outline: none; + box-shadow: 0px 0px 3px #c4e6f5; + border: 1px solid #b4dbed; } + .sweet-alert input:focus::-moz-placeholder { + transition: opacity 0.3s 0.03s ease; + opacity: 0.5; } + .sweet-alert input:focus:-ms-input-placeholder { + transition: opacity 0.3s 0.03s ease; + opacity: 0.5; } + .sweet-alert input:focus::-webkit-input-placeholder { + transition: opacity 0.3s 0.03s ease; + opacity: 0.5; } + .sweet-alert input::-moz-placeholder { + color: #bdbdbd; } + .sweet-alert input:-ms-input-placeholder { + color: #bdbdbd; } + .sweet-alert input::-webkit-input-placeholder { + color: #bdbdbd; } + .sweet-alert.show-input input { + display: block; } + .sweet-alert button { + background-color: #AEDEF4; + color: white; + border: none; + box-shadow: none; + font-size: 17px; + font-weight: 500; + -webkit-border-radius: 4px; + border-radius: 5px; + padding: 10px 32px; + margin: 26px 5px 0 5px; + cursor: pointer; } + .sweet-alert button:focus { + outline: none; + box-shadow: 0 0 2px rgba(128, 179, 235, 0.5), inset 0 0 0 1px rgba(0, 0, 0, 0.05); } + .sweet-alert button:hover { + background-color: #a1d9f2; } + .sweet-alert button:active { + background-color: #81ccee; } + .sweet-alert button.cancel { + background-color: #D0D0D0; } + .sweet-alert button.cancel:hover { + background-color: #c8c8c8; } + .sweet-alert button.cancel:active { + background-color: #b6b6b6; } + .sweet-alert button.cancel:focus { + box-shadow: rgba(197, 205, 211, 0.8) 0px 0px 2px, rgba(0, 0, 0, 0.0470588) 0px 0px 0px 1px inset !important; } + .sweet-alert button::-moz-focus-inner { + border: 0; } + .sweet-alert[data-has-cancel-button=false] button { + box-shadow: none !important; } + .sweet-alert[data-has-confirm-button=false][data-has-cancel-button=false] { + padding-bottom: 40px; } + .sweet-alert .sa-icon { + width: 80px; + height: 80px; + border: 4px solid gray; + -webkit-border-radius: 40px; + border-radius: 40px; + border-radius: 50%; + margin: 20px auto; + padding: 0; + position: relative; + box-sizing: content-box; } + .sweet-alert .sa-icon.sa-error { + border-color: #F27474; } + .sweet-alert .sa-icon.sa-error .sa-x-mark { + position: relative; + display: block; } + .sweet-alert .sa-icon.sa-error .sa-line { + position: absolute; + height: 5px; + width: 47px; + background-color: #F27474; + display: block; + top: 37px; + border-radius: 2px; } + .sweet-alert .sa-icon.sa-error .sa-line.sa-left { + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + left: 17px; } + .sweet-alert .sa-icon.sa-error .sa-line.sa-right { + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + right: 16px; } + .sweet-alert .sa-icon.sa-warning { + border-color: #F8BB86; } + .sweet-alert .sa-icon.sa-warning .sa-body { + position: absolute; + width: 5px; + height: 47px; + left: 50%; + top: 10px; + -webkit-border-radius: 2px; + border-radius: 2px; + margin-left: -2px; + background-color: #F8BB86; } + .sweet-alert .sa-icon.sa-warning .sa-dot { + position: absolute; + width: 7px; + height: 7px; + -webkit-border-radius: 50%; + border-radius: 50%; + margin-left: -3px; + left: 50%; + bottom: 10px; + background-color: #F8BB86; } + .sweet-alert .sa-icon.sa-info { + border-color: #C9DAE1; } + .sweet-alert .sa-icon.sa-info::before { + content: ""; + position: absolute; + width: 5px; + height: 29px; + left: 50%; + bottom: 17px; + border-radius: 2px; + margin-left: -2px; + background-color: #C9DAE1; } + .sweet-alert .sa-icon.sa-info::after { + content: ""; + position: absolute; + width: 7px; + height: 7px; + border-radius: 50%; + margin-left: -3px; + top: 19px; + background-color: #C9DAE1; } + .sweet-alert .sa-icon.sa-success { + border-color: #A5DC86; } + .sweet-alert .sa-icon.sa-success::before, .sweet-alert .sa-icon.sa-success::after { + content: ''; + -webkit-border-radius: 40px; + border-radius: 40px; + border-radius: 50%; + position: absolute; + width: 60px; + height: 120px; + background: white; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); } + .sweet-alert .sa-icon.sa-success::before { + -webkit-border-radius: 120px 0 0 120px; + border-radius: 120px 0 0 120px; + top: -7px; + left: -33px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + -webkit-transform-origin: 60px 60px; + transform-origin: 60px 60px; } + .sweet-alert .sa-icon.sa-success::after { + -webkit-border-radius: 0 120px 120px 0; + border-radius: 0 120px 120px 0; + top: -11px; + left: 30px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + -webkit-transform-origin: 0px 60px; + transform-origin: 0px 60px; } + .sweet-alert .sa-icon.sa-success .sa-placeholder { + width: 80px; + height: 80px; + border: 4px solid rgba(165, 220, 134, 0.2); + -webkit-border-radius: 40px; + border-radius: 40px; + border-radius: 50%; + box-sizing: content-box; + position: absolute; + left: -4px; + top: -4px; + z-index: 2; } + .sweet-alert .sa-icon.sa-success .sa-fix { + width: 5px; + height: 90px; + background-color: white; + position: absolute; + left: 28px; + top: 8px; + z-index: 1; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); } + .sweet-alert .sa-icon.sa-success .sa-line { + height: 5px; + background-color: #A5DC86; + display: block; + border-radius: 2px; + position: absolute; + z-index: 2; } + .sweet-alert .sa-icon.sa-success .sa-line.sa-tip { + width: 25px; + left: 14px; + top: 46px; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); } + .sweet-alert .sa-icon.sa-success .sa-line.sa-long { + width: 47px; + right: 8px; + top: 38px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); } + .sweet-alert .sa-icon.sa-custom { + background-size: contain; + border-radius: 0; + border: none; + background-position: center center; + background-repeat: no-repeat; } + +/* + * Animations + */ +@-webkit-keyframes showSweetAlert { + 0% { + transform: scale(0.7); + -webkit-transform: scale(0.7); } + 45% { + transform: scale(1.05); + -webkit-transform: scale(1.05); } + 80% { + transform: scale(0.95); + -webkit-transform: scale(0.95); } + 100% { + transform: scale(1); + -webkit-transform: scale(1); } } + +@keyframes showSweetAlert { + 0% { + transform: scale(0.7); + -webkit-transform: scale(0.7); } + 45% { + transform: scale(1.05); + -webkit-transform: scale(1.05); } + 80% { + transform: scale(0.95); + -webkit-transform: scale(0.95); } + 100% { + transform: scale(1); + -webkit-transform: scale(1); } } + +@-webkit-keyframes hideSweetAlert { + 0% { + transform: scale(1); + -webkit-transform: scale(1); } + 100% { + transform: scale(0.5); + -webkit-transform: scale(0.5); } } + +@keyframes hideSweetAlert { + 0% { + transform: scale(1); + -webkit-transform: scale(1); } + 100% { + transform: scale(0.5); + -webkit-transform: scale(0.5); } } + +@-webkit-keyframes slideFromTop { + 0% { + top: 0%; } + 100% { + top: 50%; } } + +@keyframes slideFromTop { + 0% { + top: 0%; } + 100% { + top: 50%; } } + +@-webkit-keyframes slideToTop { + 0% { + top: 50%; } + 100% { + top: 0%; } } + +@keyframes slideToTop { + 0% { + top: 50%; } + 100% { + top: 0%; } } + +@-webkit-keyframes slideFromBottom { + 0% { + top: 70%; } + 100% { + top: 50%; } } + +@keyframes slideFromBottom { + 0% { + top: 70%; } + 100% { + top: 50%; } } + +@-webkit-keyframes slideToBottom { + 0% { + top: 50%; } + 100% { + top: 70%; } } + +@keyframes slideToBottom { + 0% { + top: 50%; } + 100% { + top: 70%; } } + +.showSweetAlert[data-animation=pop] { + -webkit-animation: showSweetAlert 0.3s; + animation: showSweetAlert 0.3s; } + +.showSweetAlert[data-animation=none] { + -webkit-animation: none; + animation: none; } + +.showSweetAlert[data-animation=slide-from-top] { + -webkit-animation: slideFromTop 0.3s; + animation: slideFromTop 0.3s; } + +.showSweetAlert[data-animation=slide-from-bottom] { + -webkit-animation: slideFromBottom 0.3s; + animation: slideFromBottom 0.3s; } + +.hideSweetAlert[data-animation=pop] { + -webkit-animation: hideSweetAlert 0.2s; + animation: hideSweetAlert 0.2s; } + +.hideSweetAlert[data-animation=none] { + -webkit-animation: none; + animation: none; } + +.hideSweetAlert[data-animation=slide-from-top] { + -webkit-animation: slideToTop 0.4s; + animation: slideToTop 0.4s; } + +.hideSweetAlert[data-animation=slide-from-bottom] { + -webkit-animation: slideToBottom 0.3s; + animation: slideToBottom 0.3s; } + +@-webkit-keyframes animateSuccessTip { + 0% { + width: 0; + left: 1px; + top: 19px; } + 54% { + width: 0; + left: 1px; + top: 19px; } + 70% { + width: 50px; + left: -8px; + top: 37px; } + 84% { + width: 17px; + left: 21px; + top: 48px; } + 100% { + width: 25px; + left: 14px; + top: 45px; } } + +@keyframes animateSuccessTip { + 0% { + width: 0; + left: 1px; + top: 19px; } + 54% { + width: 0; + left: 1px; + top: 19px; } + 70% { + width: 50px; + left: -8px; + top: 37px; } + 84% { + width: 17px; + left: 21px; + top: 48px; } + 100% { + width: 25px; + left: 14px; + top: 45px; } } + +@-webkit-keyframes animateSuccessLong { + 0% { + width: 0; + right: 46px; + top: 54px; } + 65% { + width: 0; + right: 46px; + top: 54px; } + 84% { + width: 55px; + right: 0px; + top: 35px; } + 100% { + width: 47px; + right: 8px; + top: 38px; } } + +@keyframes animateSuccessLong { + 0% { + width: 0; + right: 46px; + top: 54px; } + 65% { + width: 0; + right: 46px; + top: 54px; } + 84% { + width: 55px; + right: 0px; + top: 35px; } + 100% { + width: 47px; + right: 8px; + top: 38px; } } + +@-webkit-keyframes rotatePlaceholder { + 0% { + transform: rotate(-45deg); + -webkit-transform: rotate(-45deg); } + 5% { + transform: rotate(-45deg); + -webkit-transform: rotate(-45deg); } + 12% { + transform: rotate(-405deg); + -webkit-transform: rotate(-405deg); } + 100% { + transform: rotate(-405deg); + -webkit-transform: rotate(-405deg); } } + +@keyframes rotatePlaceholder { + 0% { + transform: rotate(-45deg); + -webkit-transform: rotate(-45deg); } + 5% { + transform: rotate(-45deg); + -webkit-transform: rotate(-45deg); } + 12% { + transform: rotate(-405deg); + -webkit-transform: rotate(-405deg); } + 100% { + transform: rotate(-405deg); + -webkit-transform: rotate(-405deg); } } + +.animateSuccessTip { + -webkit-animation: animateSuccessTip 0.75s; + animation: animateSuccessTip 0.75s; } + +.animateSuccessLong { + -webkit-animation: animateSuccessLong 0.75s; + animation: animateSuccessLong 0.75s; } + +.sa-icon.sa-success.animate::after { + -webkit-animation: rotatePlaceholder 4.25s ease-in; + animation: rotatePlaceholder 4.25s ease-in; } + +@-webkit-keyframes animateErrorIcon { + 0% { + transform: rotateX(100deg); + -webkit-transform: rotateX(100deg); + opacity: 0; } + 100% { + transform: rotateX(0deg); + -webkit-transform: rotateX(0deg); + opacity: 1; } } + +@keyframes animateErrorIcon { + 0% { + transform: rotateX(100deg); + -webkit-transform: rotateX(100deg); + opacity: 0; } + 100% { + transform: rotateX(0deg); + -webkit-transform: rotateX(0deg); + opacity: 1; } } + +.animateErrorIcon { + -webkit-animation: animateErrorIcon 0.5s; + animation: animateErrorIcon 0.5s; } + +@-webkit-keyframes animateXMark { + 0% { + transform: scale(0.4); + -webkit-transform: scale(0.4); + margin-top: 26px; + opacity: 0; } + 50% { + transform: scale(0.4); + -webkit-transform: scale(0.4); + margin-top: 26px; + opacity: 0; } + 80% { + transform: scale(1.15); + -webkit-transform: scale(1.15); + margin-top: -6px; } + 100% { + transform: scale(1); + -webkit-transform: scale(1); + margin-top: 0; + opacity: 1; } } + +@keyframes animateXMark { + 0% { + transform: scale(0.4); + -webkit-transform: scale(0.4); + margin-top: 26px; + opacity: 0; } + 50% { + transform: scale(0.4); + -webkit-transform: scale(0.4); + margin-top: 26px; + opacity: 0; } + 80% { + transform: scale(1.15); + -webkit-transform: scale(1.15); + margin-top: -6px; } + 100% { + transform: scale(1); + -webkit-transform: scale(1); + margin-top: 0; + opacity: 1; } } + +.animateXMark { + -webkit-animation: animateXMark 0.5s; + animation: animateXMark 0.5s; } + +@-webkit-keyframes pulseWarning { + 0% { + border-color: #F8D486; } + 100% { + border-color: #F8BB86; } } + +@keyframes pulseWarning { + 0% { + border-color: #F8D486; } + 100% { + border-color: #F8BB86; } } + +.pulseWarning { + -webkit-animation: pulseWarning 0.75s infinite alternate; + animation: pulseWarning 0.75s infinite alternate; } + +@-webkit-keyframes pulseWarningIns { + 0% { + background-color: #F8D486; } + 100% { + background-color: #F8BB86; } } + +@keyframes pulseWarningIns { + 0% { + background-color: #F8D486; } + 100% { + background-color: #F8BB86; } } + +.pulseWarningIns { + -webkit-animation: pulseWarningIns 0.75s infinite alternate; + animation: pulseWarningIns 0.75s infinite alternate; } + +/* Internet Explorer 9 has some special quirks that are fixed here */ +/* The icons are not animated. */ +/* This file is automatically merged into sweet-alert.min.js through Gulp */ +/* Error icon */ +.sweet-alert .sa-icon.sa-error .sa-line.sa-left { + -ms-transform: rotate(45deg) \9; } + +.sweet-alert .sa-icon.sa-error .sa-line.sa-right { + -ms-transform: rotate(-45deg) \9; } + +/* Success icon */ +.sweet-alert .sa-icon.sa-success { + border-color: transparent\9; } + +.sweet-alert .sa-icon.sa-success .sa-line.sa-tip { + -ms-transform: rotate(45deg) \9; } + +.sweet-alert .sa-icon.sa-success .sa-line.sa-long { + -ms-transform: rotate(-45deg) \9; } diff --git a/src/main/webapp/bower_components/sweetalert/sweetalert.min.js b/src/main/webapp/bower_components/sweetalert/sweetalert.min.js new file mode 100644 index 0000000..3e4e7ff --- /dev/null +++ b/src/main/webapp/bower_components/sweetalert/sweetalert.min.js @@ -0,0 +1 @@ +!function(e,t,n){"use strict";!function o(e,t,n){function a(s,l){if(!t[s]){if(!e[s]){var i="function"==typeof require&&require;if(!l&&i)return i(s,!0);if(r)return r(s,!0);var u=new Error("Cannot find module '"+s+"'");throw u.code="MODULE_NOT_FOUND",u}var c=t[s]={exports:{}};e[s][0].call(c.exports,function(t){var n=e[s][1][t];return a(n?n:t)},c,c.exports,o,e,t,n)}return t[s].exports}for(var r="function"==typeof require&&require,s=0;s=0;)n=n.replace(" "+t+" "," ");e.className=n.replace(/^\s+|\s+$/g,"")}},i=function(e){var n=t.createElement("div");return n.appendChild(t.createTextNode(e)),n.innerHTML},u=function(e){e.style.opacity="",e.style.display="block"},c=function(e){if(e&&!e.length)return u(e);for(var t=0;t0?setTimeout(o,t):e.style.display="none"});o()},h=function(n){if("function"==typeof MouseEvent){var o=new MouseEvent("click",{view:e,bubbles:!1,cancelable:!0});n.dispatchEvent(o)}else if(t.createEvent){var a=t.createEvent("MouseEvents");a.initEvent("click",!1,!1),n.dispatchEvent(a)}else t.createEventObject?n.fireEvent("onclick"):"function"==typeof n.onclick&&n.onclick()},g=function(t){"function"==typeof t.stopPropagation?(t.stopPropagation(),t.preventDefault()):e.event&&e.event.hasOwnProperty("cancelBubble")&&(e.event.cancelBubble=!0)};a.hasClass=r,a.addClass=s,a.removeClass=l,a.escapeHtml=i,a._show=u,a.show=c,a._hide=d,a.hide=f,a.isDescendant=p,a.getTopMargin=m,a.fadeIn=v,a.fadeOut=y,a.fireClick=h,a.stopEventPropagation=g},{}],5:[function(t,o,a){Object.defineProperty(a,"__esModule",{value:!0});var r=t("./handle-dom"),s=t("./handle-swal-dom"),l=function(t,o,a){var l=t||e.event,i=l.keyCode||l.which,u=a.querySelector("button.confirm"),c=a.querySelector("button.cancel"),d=a.querySelectorAll("button[tabindex]");if(-1!==[9,13,32,27].indexOf(i)){for(var f=l.target||l.srcElement,p=-1,m=0;m"),i.innerHTML=e.html?e.text:s.escapeHtml(e.text||"").split("\n").join("
"),e.text&&s.show(i),e.customClass)s.addClass(t,e.customClass),t.setAttribute("data-custom-class",e.customClass);else{var d=t.getAttribute("data-custom-class");s.removeClass(t,d),t.setAttribute("data-custom-class","")}if(s.hide(t.querySelectorAll(".sa-icon")),e.type&&!a.isIE8()){var f=function(){for(var o=!1,a=0;ao;o++)n=parseInt(e.substr(2*o,2),16),n=Math.round(Math.min(Math.max(0,n+n*t),255)).toString(16),a+=("00"+n).substr(n.length);return a};o.extend=a,o.hexToRgb=r,o.isIE8=s,o.logStr=l,o.colorLuminance=i},{}]},{},[1]),"function"==typeof define&&define.amd?define(function(){return sweetAlert}):"undefined"!=typeof module&&module.exports&&(module.exports=sweetAlert)}(window,document); \ No newline at end of file diff --git a/src/main/webapp/css/style.css b/src/main/webapp/css/style.css new file mode 100644 index 0000000..39dfd68 --- /dev/null +++ b/src/main/webapp/css/style.css @@ -0,0 +1,32 @@ +.btn.btn-primary.noselect{ + color: #337ab7; + background-color: #fff; + border-color: #2e6da4; + } +.btn.btn-primary.selected { + color: #fff; + background-color: #337ab7; + border-color: #2e6da4; + } +.breadcrumb { + margin: 5px -10px -20px -10px; + background-color: rgb(255, 255, 255); + } +.fileInfo { + max-width: 100px; + text-overflow: ellipsis; + white-space: nowrap; + display: inline-block; + overflow: hidden; +} +.fileDelete { + position: absolute; + right: 0; + top: 7px; + color: #c74545; + text-shadow: 2px 2px 2px #615f5f; + cursor: pointer; +} +.attachmentArea { + padding : 10px; +} \ No newline at end of file diff --git a/src/main/webapp/hello.html b/src/main/webapp/hello.html index 4952598..fe62d11 100644 --- a/src/main/webapp/hello.html +++ b/src/main/webapp/hello.html @@ -47,58 +47,7 @@
-
-

尊敬的面试官你好,以下是网站和个人的简略介绍

- 网站技术选型
- 数据库表结构:点我查看
- IoC容器:spring
- web框架:springmvc
- orm框架:mybatis
- 安全框架:shiro
- 数据源:dbcp2
- 日志: sl4j
- Json: Gson
- 前端框架:Bootstrap
- -

- 使用的小技术:
- 1.教师订购图书页面orderbook.jsp使用了ajax提交json与后台交互实现局部刷新
-

- -

- 可改进的地方(成吨的问题所以只能说改进了):
- 1.完善基本的业务功能
- 2.实现网站对机器的性能等监控(这个不会,很有兴趣去实现,了解到Driud好像有相关的资料)
- 3.阅读Shiro源码更好使用shiro,并且把权限控制从角色改变为资源粒度
- 4.学习Effective Java,Clean code,重构等书籍对代码进行清理
- 5.Sql优化
- 6.Web安全设计
- 7.Resetful方式重写
-

- -

- 目前所了解过的书籍(略为只扫读过一遍,稍微详细为仔细阅读过或者有写代码和练习)
- 略:
- 《数据结构与算法》(表,栈,队列,二叉树,散列表,希尔,快排,堆排,归并,快排,并查集,图的最小生成树,最短路径,拓扑排序相关算法,动态规划)
- 《设计模式》
- 《Operating system-Internal and Design principle》(英文版)
- 《数据库系统概念》
- 《算法导论》
- 《java核心卷1》
- 《Java网络编程》
- 《Http权威指南》
- 《Java NIO》
- 《深入剖析Tomcat》(之后阅读了Tomcat8源码)
- - 稍微详细:
- 《汇编语言》
- 《C Primer Plus》
- 《Windows程序设计》
- 《Head First JSP & Servlet》(英文版)
- 《深入理解计算机》
- -

-
+
diff --git a/src/main/webapp/js/ajaxfileupload.js b/src/main/webapp/js/ajaxfileupload.js new file mode 100644 index 0000000..2517c2b --- /dev/null +++ b/src/main/webapp/js/ajaxfileupload.js @@ -0,0 +1,206 @@ + +jQuery.extend({ + + + createUploadIframe: function(id, uri) + { + //create frame + var frameId = 'jUploadFrame' + id; + var iframeHtml = '