diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index 7a12bd07069efef9e5f20a84ef6d5bc3d5cfb236..ae3880d67e25804af152863f06ac78b60d791ae0 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -61,7 +61,7 @@ demo:now:
     - master
   environment:
     name: $PACKAGE_NAME/demo
-    url: $NOW_URL
+    url: https://xpub-faraday.now.sh/
   script:
     - npm i -g --unsafe-perm now
     - cd ${HOME}/now
diff --git a/automation/.classpath b/automation/.classpath
index af599703398f3fa18bcfb98074d95bb95e8ba619..3a7fee78b7d3b51aabd19743cef74d561cb69316 100644
--- a/automation/.classpath
+++ b/automation/.classpath
@@ -70,6 +70,5 @@
 	<classpathentry kind="lib" path="/Applications/Katalon Studio.app/Contents/Eclipse/plugins/com.google.oauth-client.google-oauth-client_1.22.0.jar"/>
 	<classpathentry kind="lib" path="/Applications/Katalon Studio.app/Contents/Eclipse/plugins/com.google.http-client.google-http-client_1.22.0.jar"/>
 	<classpathentry exported="true" kind="con" path="GROOVY_SUPPORT"/>
-	<classpathentry exported="true" kind="con" path="GROOVY_DSL_SUPPORT"/>
 	<classpathentry kind="output" path="bin"/>
 </classpath>
diff --git a/automation/Object Repository/NewUser/Dr.rs b/automation/Object Repository/NewUser/Dr.rs
new file mode 100644
index 0000000000000000000000000000000000000000..eff2346d3af26506c0f90ae60007d245beaee54d
--- /dev/null
+++ b/automation/Object Repository/NewUser/Dr.rs	
@@ -0,0 +1,64 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>Dr</name>
+   <tag></tag>
+   <elementGuidId>8bdc9a24-0f0a-4806-9187-24d32796e957</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//div[contains(text(), 'Dr')]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>div</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>role</name>
+      <type>Main</type>
+      <value>option</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tabindex</name>
+      <type>Main</type>
+      <value>0</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>aria-selected</name>
+      <type>Main</type>
+      <value>true</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-cMljjf dpAtdf</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Dr</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-eNQAEJ jgsVpS&quot;]/div[@class=&quot;sc-cvbbAY cDfiQI&quot;]/div[@class=&quot;sc-jWBwVP dVZxvi&quot;]/div[@class=&quot;sc-brqgnP bTwMpG&quot;]/div[@class=&quot;sc-cMljjf dpAtdf&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/EditUser/.meta b/automation/Object Repository/NewUser/EditUser/.meta
new file mode 100644
index 0000000000000000000000000000000000000000..19883ad9e19e08afbfa1df71deffe0e36eceeaa0
--- /dev/null
+++ b/automation/Object Repository/NewUser/EditUser/.meta	
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<FolderEntity>
+   <description>folder</description>
+   <name>EditUser</name>
+   <tag></tag>
+   <folderType>WEBELEMENT</folderType>
+</FolderEntity>
diff --git a/automation/Object Repository/NewUser/a_Edit.rs b/automation/Object Repository/NewUser/a_Edit.rs
new file mode 100644
index 0000000000000000000000000000000000000000..e17c1daea2784b0d054271f634a1300ec7579677
--- /dev/null
+++ b/automation/Object Repository/NewUser/a_Edit.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>a_Edit</name>
+   <tag></tag>
+   <elementGuidId>1ab696f2-d3f9-4d16-a6d1-c6e1e9274fa7</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>#root > div > div > div.sc-drKuOJ.fmUpkt > div > table > tbody > tr:nth-child(1) > td:nth-child(7) > a</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>a</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bEjcJn hzylbl</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>href</name>
+      <type>Main</type>
+      <value>/admin/users/edit/cfcaebdf-82b0-4d06-94d6-687d126165e7</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Edit</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[1]/table[@class=&quot;sc-hzDEsm cniXiH&quot;]/tbody[1]/tr[@class=&quot;sc-jeCdPy kCgSUu&quot;]/td[7]/a[@class=&quot;sc-bEjcJn hzylbl&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/addUser.rs b/automation/Object Repository/NewUser/addUser.rs
new file mode 100644
index 0000000000000000000000000000000000000000..9a821d12d3b7f7817c73c132751d505947cf47ed
--- /dev/null
+++ b/automation/Object Repository/NewUser/addUser.rs	
@@ -0,0 +1,47 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>addUser</name>
+   <tag></tag>
+   <elementGuidId>603be35e-a2f1-4b42-9155-c50663f2f154</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//button/*[1]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value>button:first-child</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-hgHYgh ljXRif</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>  Add User</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[1]/div[@class=&quot;sc-eInJlc bZxNvb&quot;]/button[@class=&quot;sc-hgHYgh ljXRif&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/admin.rs b/automation/Object Repository/NewUser/admin.rs
new file mode 100644
index 0000000000000000000000000000000000000000..d46e98fc39661dc1a0b179c86d868c1d75524cd1
--- /dev/null
+++ b/automation/Object Repository/NewUser/admin.rs	
@@ -0,0 +1,39 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>admin</name>
+   <tag></tag>
+   <elementGuidId>9be9ae36-fc08-41ea-9e5e-66e6b3424324</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//span[contains(text(),'admin')]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>span</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>admin</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-ibxdXY kLiOmR&quot;]/div[@class=&quot;sc-iQKALj gyquxk&quot;]/div[1]/span[2]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/adminDashboard.rs b/automation/Object Repository/NewUser/adminDashboard.rs
new file mode 100644
index 0000000000000000000000000000000000000000..05527f1db5a04ac366d4c48dc5232ac2b7ade208
--- /dev/null
+++ b/automation/Object Repository/NewUser/adminDashboard.rs	
@@ -0,0 +1,47 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>adminDashboard</name>
+   <tag></tag>
+   <elementGuidId>e89c9572-6cfd-4b02-a8a3-861c8932498f</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//div[contains(text(),'Admin dashboard')]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value></value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>div</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-hrWEMg eeRLUW</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Admin dashboard</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-ibxdXY kLiOmR&quot;]/div[@class=&quot;sc-iQKALj gyquxk&quot;]/div[@class=&quot;sc-bwCtUz eJpifv&quot;]/div[@class=&quot;sc-hrWEMg eeRLUW&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/affiliation.rs b/automation/Object Repository/NewUser/affiliation.rs
new file mode 100644
index 0000000000000000000000000000000000000000..da9a81f5693daa3ea231733454745bf7018679c2
--- /dev/null
+++ b/automation/Object Repository/NewUser/affiliation.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>affiliation</name>
+   <tag></tag>
+   <elementGuidId>470c59a2-5fa0-4f30-ac66-e95cbf70d88d</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;affiliation&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>text</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>affiliation</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/author.rs b/automation/Object Repository/NewUser/author.rs
new file mode 100644
index 0000000000000000000000000000000000000000..8abb4b6cc6a3397dc458522ba0111d043689a4fd
--- /dev/null
+++ b/automation/Object Repository/NewUser/author.rs	
@@ -0,0 +1,68 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>author</name>
+   <tag></tag>
+   <elementGuidId>75e282fc-78d2-4a0d-aaaf-03af3c9ec268</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//div[contains(text(), 'Author')]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value></value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>div</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>role</name>
+      <type>Main</type>
+      <value>option</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tabindex</name>
+      <type>Main</type>
+      <value>0</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>aria-selected</name>
+      <type>Main</type>
+      <value>false</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-cMljjf gYrREv</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Author</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-eNQAEJ jgsVpS&quot;]/div[@class=&quot;sc-cvbbAY cDfiQI&quot;]/div[@class=&quot;sc-jWBwVP dVZxvi&quot;]/div[@class=&quot;sc-brqgnP bTwMpG&quot;]/div[@class=&quot;sc-cMljjf gYrREv&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/back.rs b/automation/Object Repository/NewUser/back.rs
new file mode 100644
index 0000000000000000000000000000000000000000..8f46e5514dfba5d7f2c99bf822dc4108f9306faf
--- /dev/null
+++ b/automation/Object Repository/NewUser/back.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>back</name>
+   <tag></tag>
+   <elementGuidId>31117721-59ff-4d5f-ac9c-98912b39b191</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//button[contains(text(),'Back')]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-VigVT eawDXx</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Back</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[@class=&quot;sc-eTpRJs juzepW&quot;]/button[@class=&quot;sc-VigVT eawDXx&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/editorInChied.rs b/automation/Object Repository/NewUser/editorInChied.rs
new file mode 100644
index 0000000000000000000000000000000000000000..5dcfb48b271c9523027480c02c7b6b2d5c87ddc0
--- /dev/null
+++ b/automation/Object Repository/NewUser/editorInChied.rs	
@@ -0,0 +1,40 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>editorInChied</name>
+   <tag></tag>
+   <elementGuidId>34eca5ab-ac60-4162-b582-26cf8ae1d055</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//label[@class=&quot;sc-kAzzGY dnReMb&quot;]/input[@name=&quot;editorInChief&quot;]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value></value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>span</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Editor in Chief</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-iybRtq cyLdLK&quot;]/div[@class=&quot;sc-iQtOjA FBgTe&quot;]/div[3]/label[@class=&quot;sc-kAzzGY dnReMb&quot;]/span[1]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/email.rs b/automation/Object Repository/NewUser/email.rs
new file mode 100644
index 0000000000000000000000000000000000000000..ec8cb51872a5e5d8babab0115dbe91a1ac5cbecd
--- /dev/null
+++ b/automation/Object Repository/NewUser/email.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>email</name>
+   <tag></tag>
+   <elementGuidId>1858a722-d885-4a1e-b442-cf4f5e56dc49</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;email&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>text</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>email</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/firstName.rs b/automation/Object Repository/NewUser/firstName.rs
new file mode 100644
index 0000000000000000000000000000000000000000..1c911543bf1c746cd35033a4498bdf94b8a2a4a4
--- /dev/null
+++ b/automation/Object Repository/NewUser/firstName.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>firstName</name>
+   <tag></tag>
+   <elementGuidId>1acf4240-f00b-4f93-8833-625af953cbc7</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;firstName&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>text</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>firstName</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/lastName.rs b/automation/Object Repository/NewUser/lastName.rs
new file mode 100644
index 0000000000000000000000000000000000000000..04f64121cb9625f92c7d58f7e8ba4415611c8fb4
--- /dev/null
+++ b/automation/Object Repository/NewUser/lastName.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>lastName</name>
+   <tag></tag>
+   <elementGuidId>76427985-e357-418e-bd3c-7c9f6e5821bb</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;lastName&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>text</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>lastName</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/login.rs b/automation/Object Repository/NewUser/login.rs
new file mode 100644
index 0000000000000000000000000000000000000000..43a596efe3f0b88cd852a3dee00a5749203b0f9d
--- /dev/null
+++ b/automation/Object Repository/NewUser/login.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>login</name>
+   <tag></tag>
+   <elementGuidId>13c40cbc-2634-4147-b93b-717f7ea9cc2b</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>button[type=&quot;submit&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>submit</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-jTzLTM jwsELq</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Login</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-TOsTZ beQaWr&quot;]/form[1]/button[@class=&quot;sc-jTzLTM jwsELq&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/password.rs b/automation/Object Repository/NewUser/password.rs
new file mode 100644
index 0000000000000000000000000000000000000000..fcbea6dfa6e6325f1f5ea2378b78a03cfaf165ac
--- /dev/null
+++ b/automation/Object Repository/NewUser/password.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>password</name>
+   <tag></tag>
+   <elementGuidId>7f5f3c44-335f-4a8e-9e97-46646ad1755b</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;password&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>password</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>password</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-TOsTZ beQaWr&quot;]/form[1]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/roleAdmin.rs b/automation/Object Repository/NewUser/roleAdmin.rs
new file mode 100644
index 0000000000000000000000000000000000000000..e568d0ea2dc034399094c8528fb379685d58ee0a
--- /dev/null
+++ b/automation/Object Repository/NewUser/roleAdmin.rs	
@@ -0,0 +1,40 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>roleAdmin</name>
+   <tag></tag>
+   <elementGuidId>e32a2bfe-254a-42d6-b533-255570389045</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//div[contains(text(),'Editor in Chief')]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value>div[data-test=&quot;role-selector&quot;] div[role=&quot;option&quot;]:last-child</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>span</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Admin</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-iybRtq cyLdLK&quot;]/div[@class=&quot;sc-iQtOjA FBgTe&quot;]/div[4]/label[@class=&quot;sc-kAzzGY dnReMb&quot;]/span[1]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/roleDropDown.rs b/automation/Object Repository/NewUser/roleDropDown.rs
new file mode 100644
index 0000000000000000000000000000000000000000..b450ce1c88ec543c897a7cad7dbd3c9c461e0979
--- /dev/null
+++ b/automation/Object Repository/NewUser/roleDropDown.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>roleDropDown</name>
+   <tag></tag>
+   <elementGuidId>7e0c179c-c8a8-4c69-96b1-d5eed9615c3e</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>div[data-test=&quot;role-selector&quot;] button</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-kEYyzF eQSWqQ</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Choose in the listâ–¼</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-eNQAEJ jgsVpS&quot;]/div[@class=&quot;sc-cvbbAY cDfiQI&quot;]/button[@class=&quot;sc-kEYyzF eQSWqQ&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/save.rs b/automation/Object Repository/NewUser/save.rs
new file mode 100644
index 0000000000000000000000000000000000000000..4999eff76563cb36ded2ab248b83a75e33c3d78f
--- /dev/null
+++ b/automation/Object Repository/NewUser/save.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>save</name>
+   <tag></tag>
+   <elementGuidId>e889f3f3-ff55-4aa4-bbda-6cbab91338b1</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>button[type=&quot;submit&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>submit</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-jTzLTM jwsELq</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Save user</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[@class=&quot;sc-eTpRJs juzepW&quot;]/button[@class=&quot;sc-jTzLTM jwsELq&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/signUp.rs b/automation/Object Repository/NewUser/signUp.rs
new file mode 100644
index 0000000000000000000000000000000000000000..e54272f1a5de32f3214806bc16d8e2085b74097e
--- /dev/null
+++ b/automation/Object Repository/NewUser/signUp.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>signUp</name>
+   <tag></tag>
+   <elementGuidId>19400002-75ea-4914-8827-72d5fa40aaf3</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>a[href=&quot;/signup&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>a</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-gisBJw eWHBkB</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>href</name>
+      <type>Main</type>
+      <value>/signup</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Sign up</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-TOsTZ beQaWr&quot;]/div[@class=&quot;sc-eerKOB eFhTIp&quot;]/a[@class=&quot;sc-gisBJw eWHBkB&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/td_vlad.stegarunewuserthinslic.rs b/automation/Object Repository/NewUser/td_vlad.stegarunewuserthinslic.rs
new file mode 100644
index 0000000000000000000000000000000000000000..f4ef7825b8ff65cf36154ff32576a771dc69eb52
--- /dev/null
+++ b/automation/Object Repository/NewUser/td_vlad.stegarunewuserthinslic.rs	
@@ -0,0 +1,40 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>td_vlad.stegarunewuserthinslic</name>
+   <tag></tag>
+   <elementGuidId>1ee7b131-9b37-44ca-a75a-e710f5aa3d91</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>#root > div > div > div.sc-drKuOJ.fmUpkt > div > table > tbody > tr:nth-child(1)</value>
+      </entry>
+      <entry>
+         <key>XPATH</key>
+         <value></value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>td</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>vlad.stegaru+newuser@thinslices.com</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[1]/table[@class=&quot;sc-hzDEsm cniXiH&quot;]/tbody[1]/tr[@class=&quot;sc-jeCdPy kCgSUu&quot;]/td[2]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/titleDropDown.rs b/automation/Object Repository/NewUser/titleDropDown.rs
new file mode 100644
index 0000000000000000000000000000000000000000..32cc7ea26883b5e2301420161a29cba20b44dc17
--- /dev/null
+++ b/automation/Object Repository/NewUser/titleDropDown.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>titleDropDown</name>
+   <tag></tag>
+   <elementGuidId>fb697c85-1d88-41ce-b084-64f1bf1ba28f</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>div[data-test=&quot;title-selector&quot;] button</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>button</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-kEYyzF eQSWqQ</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Choose in the listâ–¼</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-ugnQR keFDzo&quot;]/form[@class=&quot;sc-eIHaNI bdGTel&quot;]/div[1]/div[@class=&quot;sc-cpmKsF huoLCL&quot;]/div[@class=&quot;sc-kQsIoO fuwMDp&quot;]/div[2]/div[@class=&quot;sc-eNQAEJ jgsVpS&quot;]/div[@class=&quot;sc-cvbbAY cDfiQI&quot;]/button[@class=&quot;sc-kEYyzF eQSWqQ&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/username.rs b/automation/Object Repository/NewUser/username.rs
new file mode 100644
index 0000000000000000000000000000000000000000..1b371925b13ac14f1216df05b46eef7d44846eee
--- /dev/null
+++ b/automation/Object Repository/NewUser/username.rs	
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>username</name>
+   <tag></tag>
+   <elementGuidId>5478eb88-8fb8-483f-8f82-f56766b37933</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>CSS</key>
+         <value>input[name=&quot;username&quot;]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>CSS</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>input</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>type</name>
+      <type>Main</type>
+      <value>text</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-bRBYWo cBIccu</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>name</name>
+      <type>Main</type>
+      <value>username</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-TOsTZ beQaWr&quot;]/form[1]/div[@class=&quot;sc-csuQGl cQCuEk&quot;]/input[@class=&quot;sc-bRBYWo cBIccu&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Object Repository/NewUser/users.rs b/automation/Object Repository/NewUser/users.rs
new file mode 100644
index 0000000000000000000000000000000000000000..741e7f5528791d64e35ab023b30a877a1422ef02
--- /dev/null
+++ b/automation/Object Repository/NewUser/users.rs	
@@ -0,0 +1,47 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<WebElementEntity>
+   <description></description>
+   <name>users</name>
+   <tag></tag>
+   <elementGuidId>fc06cfc7-c7e0-449f-b85c-d7c1f34f21c3</elementGuidId>
+   <selectorCollection>
+      <entry>
+         <key>XPATH</key>
+         <value>//span[contains(text(),'Users')]</value>
+      </entry>
+      <entry>
+         <key>CSS</key>
+         <value>//span[contains(text(),'Users')]</value>
+      </entry>
+   </selectorCollection>
+   <selectorMethod>XPATH</selectorMethod>
+   <useRalativeImagePath>false</useRalativeImagePath>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>tag</name>
+      <type>Main</type>
+      <value>div</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>class</name>
+      <type>Main</type>
+      <value>sc-eXNvrr hVBWZK</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>true</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>text</name>
+      <type>Main</type>
+      <value>Users</value>
+   </webElementProperties>
+   <webElementProperties>
+      <isSelected>false</isSelected>
+      <matchCondition>equals</matchCondition>
+      <name>xpath</name>
+      <type>Main</type>
+      <value>id(&quot;root&quot;)/div[@class=&quot;sc-cmTdod hZxvxw&quot;]/div[@class=&quot;sc-dyGzUR bQYZEl&quot;]/div[@class=&quot;sc-drKuOJ fmUpkt&quot;]/div[@class=&quot;sc-hIVACf dydoGZ&quot;]/div[@class=&quot;sc-gVyKpa knVGhf&quot;]/div[@class=&quot;sc-eXNvrr hVBWZK&quot;]</value>
+   </webElementProperties>
+</WebElementEntity>
diff --git a/automation/Scripts/Add a new user/Add a new user/Script1521123804636.groovy b/automation/Scripts/Add a new user/Add a new user/Script1521123804636.groovy
new file mode 100644
index 0000000000000000000000000000000000000000..9c9b4fd5dac17e68e54db977ce98921e656337f0
--- /dev/null
+++ b/automation/Scripts/Add a new user/Add a new user/Script1521123804636.groovy	
@@ -0,0 +1,103 @@
+import static com.kms.katalon.core.checkpoint.CheckpointFactory.findCheckpoint
+import static com.kms.katalon.core.testcase.TestCaseFactory.findTestCase
+import static com.kms.katalon.core.testdata.TestDataFactory.findTestData
+import static com.kms.katalon.core.testobject.ObjectRepository.findTestObject
+import com.kms.katalon.core.checkpoint.Checkpoint as Checkpoint
+import com.kms.katalon.core.checkpoint.CheckpointFactory as CheckpointFactory
+import com.kms.katalon.core.mobile.keyword.MobileBuiltInKeywords as MobileBuiltInKeywords
+import com.kms.katalon.core.mobile.keyword.MobileBuiltInKeywords as Mobile
+import com.kms.katalon.core.model.FailureHandling as FailureHandling
+import com.kms.katalon.core.testcase.TestCase as TestCase
+import com.kms.katalon.core.testcase.TestCaseFactory as TestCaseFactory
+import com.kms.katalon.core.testdata.TestData as TestData
+import com.kms.katalon.core.testdata.TestDataFactory as TestDataFactory
+import com.kms.katalon.core.testobject.ObjectRepository as ObjectRepository
+import com.kms.katalon.core.testobject.TestObject as TestObject
+import com.kms.katalon.core.webservice.keyword.WSBuiltInKeywords as WSBuiltInKeywords
+import com.kms.katalon.core.webservice.keyword.WSBuiltInKeywords as WS
+import com.kms.katalon.core.webui.keyword.WebUiBuiltInKeywords as WebUiBuiltInKeywords
+import com.kms.katalon.core.webui.keyword.WebUiBuiltInKeywords as WebUI
+import internal.GlobalVariable as GlobalVariable
+
+WebUI.openBrowser(null)
+
+WebUI.navigateToUrl('https://xpub-faraday.now.sh')
+
+username = findTestObject('NewUser/username')
+
+WebUI.click(username)
+
+WebUI.setText(username, 'admin')
+
+password = findTestObject('NewUser/password')
+
+WebUI.click(password)
+
+WebUI.setText(password, 'admin123')
+
+login = findTestObject('NewUser/login')
+
+WebUI.click(login)
+
+admin = findTestObject('NewUser/admin')
+
+WebUI.click(admin)
+
+adminDashboard = findTestObject('NewUser/adminDashboard')
+
+WebUI.click(adminDashboard)
+
+users = findTestObject('NewUser/users')
+
+WebUI.waitForElementVisible(users, 2)
+
+WebUI.click(users)
+
+addUser = findTestObject('NewUser/addUser')
+
+WebUI.click(addUser)
+
+email = findTestObject('NewUser/email')
+
+WebUI.click(email)
+
+WebUI.setText(email, 'bogdan.cochior+author@thinslices.com')
+
+roleDropDown = findTestObject('NewUser/roleDropDown')
+
+WebUI.click(roleDropDown)
+
+author = findTestObject('NewUser/author')
+
+WebUI.click(author)
+
+firstName = findTestObject('NewUser/firstName')
+
+WebUI.click(firstName)
+
+WebUI.setText(firstName, 'Bogdan Author')
+
+lastName = findTestObject('NewUser/lastName')
+
+WebUI.click(lastName)
+
+WebUI.setText(lastName, 'Test')
+
+affiliation = findTestObject('NewUser/affiliation')
+
+WebUI.click(affiliation)
+
+WebUI.setText(affiliation, 'College')
+
+title = findTestObject('NewUser/titleDropDown')
+
+WebUI.click(title)
+
+dr = findTestObject('NewUser/Dr')
+
+WebUI.click(dr)
+
+save = findTestObject('NewUser/save')
+
+WebUI.click(save)
+
diff --git a/automation/Scripts/Add a new user/Edit new user/Script1521147575383.groovy b/automation/Scripts/Add a new user/Edit new user/Script1521147575383.groovy
new file mode 100644
index 0000000000000000000000000000000000000000..fc39b005f064450c360cbe989bd9a164ea33400f
--- /dev/null
+++ b/automation/Scripts/Add a new user/Edit new user/Script1521147575383.groovy	
@@ -0,0 +1,85 @@
+import static com.kms.katalon.core.checkpoint.CheckpointFactory.findCheckpoint
+import static com.kms.katalon.core.testcase.TestCaseFactory.findTestCase
+import static com.kms.katalon.core.testdata.TestDataFactory.findTestData
+import static com.kms.katalon.core.testobject.ObjectRepository.findTestObject
+import com.kms.katalon.core.checkpoint.Checkpoint as Checkpoint
+import com.kms.katalon.core.checkpoint.CheckpointFactory as CheckpointFactory
+import com.kms.katalon.core.mobile.keyword.MobileBuiltInKeywords as MobileBuiltInKeywords
+import com.kms.katalon.core.mobile.keyword.MobileBuiltInKeywords as Mobile
+import com.kms.katalon.core.model.FailureHandling as FailureHandling
+import com.kms.katalon.core.testcase.TestCase as TestCase
+import com.kms.katalon.core.testcase.TestCaseFactory as TestCaseFactory
+import com.kms.katalon.core.testdata.TestData as TestData
+import com.kms.katalon.core.testdata.TestDataFactory as TestDataFactory
+import com.kms.katalon.core.testobject.ObjectRepository as ObjectRepository
+import com.kms.katalon.core.testobject.TestObject as TestObject
+import com.kms.katalon.core.webservice.keyword.WSBuiltInKeywords as WSBuiltInKeywords
+import com.kms.katalon.core.webservice.keyword.WSBuiltInKeywords as WS
+import com.kms.katalon.core.webui.keyword.WebUiBuiltInKeywords as WebUiBuiltInKeywords
+import com.kms.katalon.core.webui.keyword.WebUiBuiltInKeywords as WebUI
+import internal.GlobalVariable as GlobalVariable
+
+WebUI.openBrowser(null)
+WebUI.navigateToUrl('https://xpub-faraday.now.sh')
+
+username = findTestObject("NewUser/username")
+WebUI.click(username)
+WebUI.setText(username, 'admin')
+
+password = findTestObject("NewUser/password")
+WebUI.click(password)
+WebUI.setText(password, 'admin123')
+
+login = findTestObject("NewUser/login")
+WebUI.click(login)
+
+admin = findTestObject("NewUser/admin")
+WebUI.click(admin)
+
+adminDashboard = findTestObject("NewUser/adminDashboard")
+WebUI.click(adminDashboard)
+
+users = findTestObject("NewUser/users")
+WebUI.waitForElementVisible(users, 2)
+WebUI.click(users)
+
+editUserVlad = findTestObject("NuewUser/td_vlad.stegarunewuserthinslic")
+WebUI.mouseOver(editUserVlad)
+WebUI.waitForElementVisible(edit, 2)
+
+edit = findTestObject("NewUSer/a_Edit")
+WebUI.click(edit)
+
+firstName = findTestObject("NewUser/firstName")
+WebUI.click(firstName)
+WebUI.setText(firstName, 'John')
+
+lastName = findTestObject("NewUser/lastName")
+WebUI.click(lastName)
+WebUI.setText(lastName, 'Smith')
+
+affiliation = findTestObject("NewUser/affiliation")
+WebUI.click(affiliation)
+WebUI.setText(affiliation, 'University')
+
+title = findTestObject("NewUser/titleDropDown")
+WebUI.click(title)
+
+dr = findTestObject("NewUser/dr")
+WebUI.click(dr)
+
+editorInChief = findTestObject("NewUser/editorInChief")
+WebUI.click(editorInChief)
+
+save = findTestObject("NewUser/save")
+WebUI.click(save)
+
+
+
+
+
+
+
+
+
+
diff --git a/automation/Scripts/Add new manuscript/Add a new manuscript/Script1520433593112.groovy b/automation/Scripts/Add new manuscript/Add a new manuscript/Script1520433593112.groovy
index f48875d6f73388e67258bfe31093ccf16bf047b9..de38d51f58d176fe41cb72d88137550c9cd7d9ba 100644
--- a/automation/Scripts/Add new manuscript/Add a new manuscript/Script1520433593112.groovy	
+++ b/automation/Scripts/Add new manuscript/Add a new manuscript/Script1520433593112.groovy	
@@ -23,7 +23,7 @@ import org.openqa.selenium.Keys as Keys
 
 WebUI.openBrowser(null)
 
-WebUI.navigateToUrl('http://localhost:3000')
+WebUI.navigateToUrl('https://xpub-faraday.now.sh')
 
 username = findTestObject('SignIn/usernameField')
 
@@ -57,8 +57,6 @@ WebUI.waitForElementVisible(newButton, 2)
 
 WebUI.click(hindawiFaraday)
 
-WebUI.click(hindawiFaraday)
-
 issue = findTestObject('NewManuscript/journalfFieldSelection/Issue')
 
 WebUI.click(issue)
diff --git a/automation/Scripts/Resume submission Redirect/Script1520866853834.groovy b/automation/Scripts/Resume submission Redirect/Script1520866853834.groovy
index 4c915e92dc984af5ce22e5693a31a941a704bc36..1f5ad7619f9f37b7e25bc210c013f3d43e6042be 100644
--- a/automation/Scripts/Resume submission Redirect/Script1520866853834.groovy	
+++ b/automation/Scripts/Resume submission Redirect/Script1520866853834.groovy	
@@ -36,8 +36,11 @@ WebUI.setText(password, '123123123')
 loginButton = findTestObject('SignIn/LoginButton')
 WebUI.click(loginButton)
 
+New = findTestObject("NewManuscript/journalFieldSelection/New")
+WebUI.click(New)
+
 resumeSubmission = findTestObject('Resume/resumeSubmission')
 WebUI.click(resumeSubmission)
 
-Cancel = findTestObject('Object Repository/NewManuscript/journalfFieldSelection/Cancel')
-WebUI.click(Cancel)
\ No newline at end of file
+cancel = findTestObject("NewManuscript/journalFieldSelection/Cancel")
+WebUI.click(cancel)
diff --git a/automation/Test Cases/Add a new user/Add a new user.tc b/automation/Test Cases/Add a new user/Add a new user.tc
new file mode 100644
index 0000000000000000000000000000000000000000..90ffcdbf6a659e5b6ee4bf35fe0ec6ca828e6f05
--- /dev/null
+++ b/automation/Test Cases/Add a new user/Add a new user.tc	
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<TestCaseEntity>
+   <description></description>
+   <name>Add a new user</name>
+   <tag></tag>
+   <comment></comment>
+   <testCaseGuid>4fb461a2-86c3-481b-bdab-82f1038de954</testCaseGuid>
+</TestCaseEntity>
diff --git a/automation/Test Cases/Add a new user/Edit new user.tc b/automation/Test Cases/Add a new user/Edit new user.tc
new file mode 100644
index 0000000000000000000000000000000000000000..ff1df9a36c00423131cdfde3cb6b4221ec7418a1
--- /dev/null
+++ b/automation/Test Cases/Add a new user/Edit new user.tc	
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<TestCaseEntity>
+   <description></description>
+   <name>Edit new user</name>
+   <tag></tag>
+   <comment></comment>
+   <testCaseGuid>8834effa-adeb-4c54-829d-0f79db5f7d4f</testCaseGuid>
+</TestCaseEntity>
diff --git a/packages/component-aws-download/index.js b/packages/component-aws-download/index.js
deleted file mode 100644
index 140b65ac0183438e989b7e7f552b3498baa32820..0000000000000000000000000000000000000000
--- a/packages/component-aws-download/index.js
+++ /dev/null
@@ -1,5 +0,0 @@
-require('dotenv').config()
-
-module.exports = {
-  backend: () => app => require('./src/FileBackend')(app),
-}
diff --git a/packages/component-aws-download/package.json b/packages/component-aws-download/package.json
deleted file mode 100644
index 4d54d2c1d945d705640586d78e3b8cace92fd724..0000000000000000000000000000000000000000
--- a/packages/component-aws-download/package.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
-  "name": "component-aws-download",
-  "version": "0.0.1",
-  "main": "index.js",
-  "license": "MIT",
-  "dependencies": {
-    "archiver": "^2.1.1",
-    "aws-sdk": "^2.185.0",
-    "body-parser": "^1.17.2",
-    "multer": "^1.3.0",
-    "multer-s3": "^2.7.0",
-    "node-mocks-http": "^1.6.6"
-  },
-  "peerDependencies": {
-    "@pubsweet/logger": "^0.0.1",
-    "pubsweet-server": "^1.0.1"
-  }
-}
diff --git a/packages/component-aws-download/src/FileBackend.js b/packages/component-aws-download/src/FileBackend.js
deleted file mode 100644
index 74c4a5a76f1d952ccc1405dcd90ac39b52e26718..0000000000000000000000000000000000000000
--- a/packages/component-aws-download/src/FileBackend.js
+++ /dev/null
@@ -1,62 +0,0 @@
-const AWS = require('aws-sdk')
-const _ = require('lodash')
-const util = require('util')
-const config = require('config')
-const archiver = require('archiver')
-// const logger = require('@pubsweet/logger')
-
-const s3Config = _.get(config, 'pubsweet-component-aws-s3')
-
-const FileBackend = app => {
-  const authBearer = app.locals.passport.authenticate('bearer', {
-    session: false,
-  })
-  AWS.config.update({
-    secretAccessKey: s3Config.secretAccessKey,
-    accessKeyId: s3Config.accessKeyId,
-    region: s3Config.region,
-  })
-  const s3 = new AWS.S3()
-
-  app.get('/api/fileZip/:fragmentId', authBearer, async (req, res) => {
-    const archive = archiver('zip')
-    const { fragmentId } = req.params
-    const getObject = util.promisify(s3.getObject.bind(s3))
-    const listObjects = util.promisify(s3.listObjects.bind(s3))
-
-    try {
-      archive.pipe(res)
-      res.attachment(`${fragmentId}-archive.zip`)
-
-      const params = {
-        Bucket: s3Config.bucket,
-        Prefix: `${fragmentId}`,
-      }
-
-      const s3Items = await listObjects(params)
-      const s3Files = await Promise.all(
-        s3Items.Contents.map(content =>
-          getObject({
-            Bucket: s3Config.bucket,
-            Key: content.Key,
-          }),
-        ),
-      )
-
-      s3Files.forEach(f => {
-        archive.append(f.Body, {
-          name: `${_.get(f, 'Metadata.filetype') || 'supplementary'}/${_.get(
-            f,
-            'Metadata.filename',
-          ) || f.ETag}`,
-        })
-      })
-
-      archive.finalize()
-    } catch (err) {
-      res.status(err.statusCode).json({ error: err.message })
-    }
-  })
-}
-
-module.exports = FileBackend
diff --git a/packages/component-invite/src/controllers/inviteGlobalRole.js b/packages/component-invite/src/controllers/inviteGlobalRole.js
index 82558319506f30622daa03130ead2ee25f2cb92a..4cf92182fd3a3b8a52abc9081d3a043a5ad589ed 100644
--- a/packages/component-invite/src/controllers/inviteGlobalRole.js
+++ b/packages/component-invite/src/controllers/inviteGlobalRole.js
@@ -47,7 +47,8 @@ module.exports = async (body, models, res, url) => {
 
       return res.status(200).json(newUser)
     } catch (e) {
-      return res.status(500).json({ error: e.message })
+      logger.error(e.message)
+      return res.status(500).json({ error: 'Email could not be sent.' })
     }
   }
 }
diff --git a/packages/component-local-aws/index.js b/packages/component-local-aws/index.js
deleted file mode 100644
index 140b65ac0183438e989b7e7f552b3498baa32820..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/index.js
+++ /dev/null
@@ -1,5 +0,0 @@
-require('dotenv').config()
-
-module.exports = {
-  backend: () => app => require('./src/FileBackend')(app),
-}
diff --git a/packages/component-local-aws/package.json b/packages/component-local-aws/package.json
deleted file mode 100644
index b38c67c0a3e07d5a3d4596db3ad356a20eb1c2ca..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/package.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
-  "name": "component-local-aws",
-  "version": "1.0.0",
-  "main": "index.js",
-  "license": "MIT",
-  "dependencies": {
-    "aws-sdk": "^2.185.0",
-    "body-parser": "^1.17.2",
-    "multer": "^1.3.0",
-    "multer-s3": "^2.7.0",
-    "node-mocks-http": "^1.6.6",
-    "nodemailer": "^4.4.2"
-  },
-  "peerDependencies": {
-    "@pubsweet/logger": "^0.0.1",
-    "pubsweet-server": "^1.0.1"
-  }
-}
diff --git a/packages/component-local-aws/src/FileBackend.js b/packages/component-local-aws/src/FileBackend.js
deleted file mode 100644
index b7866aa58574c21c3773ca443041bda361270cfe..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/FileBackend.js
+++ /dev/null
@@ -1,45 +0,0 @@
-const _ = require('lodash')
-const AWS = require('aws-sdk')
-const config = require('config')
-
-const s3Config = _.get(config, 'pubsweet-component-aws-s3')
-
-const FileBackend = app => {
-  const authBearer = app.locals.passport.authenticate('bearer', {
-    session: false,
-  })
-  AWS.config.update({
-    secretAccessKey: s3Config.secretAccessKey,
-    accessKeyId: s3Config.accessKeyId,
-    region: s3Config.region,
-  })
-  const s3 = new AWS.S3()
-  const upload = require('./middeware/upload').setupMulter(s3)
-
-  app.post(
-    '/api/files',
-    authBearer,
-    upload.single('file'),
-    require('./routeHandlers/postFile'),
-  )
-
-  app.get(
-    '/api/files/:fragmentId/:fileId',
-    authBearer,
-    require('./routeHandlers/getSignedUrl')(s3, s3Config),
-  )
-
-  app.get(
-    '/api/files/:fragmentId',
-    authBearer,
-    require('./routeHandlers/zipFiles')(s3, s3Config),
-  )
-
-  app.delete(
-    '/api/files/:fragmentId/:fileId',
-    authBearer,
-    require('./routeHandlers/deleteFile')(s3, s3Config),
-  )
-}
-
-module.exports = FileBackend
diff --git a/packages/component-local-aws/src/FileBackend.test.js b/packages/component-local-aws/src/FileBackend.test.js
deleted file mode 100644
index 95a026ff5866440953da6c75cee6042589d1abe1..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/FileBackend.test.js
+++ /dev/null
@@ -1,188 +0,0 @@
-process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0'
-process.env.SUPPRESS_NO_CONFIG_WARNING = true
-
-const httpMocks = require('node-mocks-http')
-
-const zipHandler = require('./routeHandlers/zipFiles')
-
-describe('ValidateFile for multer fileFilter', () => {
-  it('should return TRUE when fileType is supplementary', () => {
-    const validateFile = require('./middeware/upload').validateFile(
-      ...buildValidateFileParams('supplementary', 'image/png'),
-    )
-    expect(validateFile).toBe(true)
-  })
-  it('should return TRUE when fileType is manuscripts or coverLetter and the file is either Word Doc or PDF', () => {
-    const randFileType = getRandValueFromArray(['manuscripts', 'coverLetter'])
-    const randMimeType = getRandValueFromArray([
-      'application/pdf',
-      'application/msword',
-      'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
-    ])
-
-    const validateFile = require('./middeware/upload').validateFile(
-      ...buildValidateFileParams(randFileType, randMimeType),
-    )
-    expect(validateFile).toBe(true)
-  })
-  it('should return FALSE when fileType is manuscripts or coverLetter and the file is neither Word Doc or PDF', () => {
-    const randFileType = getRandValueFromArray(['manuscripts', 'coverLetter'])
-    const randMimeType = getRandValueFromArray([
-      'text/plain',
-      'text/html',
-      'image/jpeg',
-      'image/png',
-    ])
-
-    const validateFile = require('./middeware/upload').validateFile(
-      ...buildValidateFileParams(randFileType, randMimeType),
-    )
-    expect(validateFile).toBe(false)
-  })
-})
-
-describe('Upload file route handler', () => {
-  it('should return success when the file passed validation', async () => {
-    const file = {
-      key: '123abc',
-      originalname: 'file.txt',
-      size: 128,
-    }
-    const req = httpMocks.createRequest({
-      file,
-    })
-    const res = httpMocks.createResponse()
-    await require('./routeHandlers/postFile')(req, res)
-    expect(res.statusCode).toBe(200)
-    const data = JSON.parse(res._getData())
-    expect(data.id).toEqual(file.key)
-    expect(data.name).toEqual(file.originalname)
-    expect(data.size).toEqual(file.size)
-  })
-  it('should return an error when the file failed validation', async () => {
-    const req = httpMocks.createRequest({
-      fileValidationError: 'Only Word documents and PDFs are allowed',
-    })
-    const res = httpMocks.createResponse()
-    await require('./routeHandlers/postFile')(req, res)
-    expect(res.statusCode).toBe(400)
-    const data = JSON.parse(res._getData())
-    expect(data.error).toEqual(req.fileValidationError)
-  })
-})
-
-describe('Zip files endpoint', () => {
-  const testObject = {
-    Key: 'KeyToMyHeart',
-    Body: Buffer.alloc(10),
-    Metadata: {
-      filetype: 'manuscripts',
-      filename: 'test.txt',
-    },
-  }
-  const mockBucket = {
-    RandomKey: {
-      Contents: [testObject, testObject],
-    },
-  }
-
-  const s3 = {}
-  const mocks = {}
-  let mockArchiver = null
-  const s3Config = {
-    bucket: 'TestBucket',
-  }
-  beforeAll(() => {
-    s3.getObject = jest.fn((params, cb) => {
-      cb(null, testObject)
-    })
-
-    s3.listObjects = jest.fn((params, cb) => {
-      cb(null, mockBucket[params.Prefix])
-    })
-    mocks.pipe = jest.fn()
-    mocks.append = jest.fn()
-    mocks.finalize = jest.fn()
-    mocks.attachment = jest.fn()
-
-    mockArchiver = jest.fn(p => ({
-      pipe: mocks.pipe,
-      append: mocks.append,
-      finalize: mocks.finalize,
-    }))
-  })
-  afterEach(() => {
-    s3.getObject.mockClear()
-    s3.listObjects.mockClear()
-    mocks.pipe.mockClear()
-    mocks.append.mockClear()
-    mocks.attachment.mockClear()
-  })
-  it(`no zipping if no files found`, async () => {
-    const zipFiles = zipHandler(s3, s3Config, mockArchiver)
-    const request = httpMocks.createRequest({
-      method: 'GET',
-      params: {
-        fragmentId: 'NotFoundKey',
-      },
-    })
-    const response = httpMocks.createResponse()
-    response.attachment = mocks.attachment
-
-    await zipFiles(request, response)
-
-    expect(s3.listObjects.mock.calls).toHaveLength(1)
-    expect(s3.getObject.mock.calls).toHaveLength(0)
-    expect(mocks.attachment.mock.calls).toHaveLength(0)
-    expect(mocks.append.mock.calls).toHaveLength(0)
-    expect(mocks.pipe.mock.calls).toHaveLength(0)
-
-    const responseData = JSON.parse(response._getData())
-
-    expect(responseData.message).toEqual(
-      `No files found for the requested manuscript.`,
-    )
-    expect(response._getStatusCode()).toEqual(204)
-  })
-  it('zips all the files', async () => {
-    const zipFiles = zipHandler(s3, s3Config, mockArchiver)
-
-    const request = httpMocks.createRequest({
-      method: 'GET',
-      params: {
-        fragmentId: 'RandomKey',
-      },
-    })
-    const response = httpMocks.createResponse()
-    response.attachment = mocks.attachment
-
-    await zipFiles(request, response)
-
-    expect(s3.listObjects.mock.calls).toHaveLength(1)
-    expect(s3.getObject.mock.calls).toHaveLength(2)
-    expect(mocks.attachment.mock.calls).toHaveLength(1)
-    expect(mocks.attachment.mock.calls[0][0]).toEqual('RandomKey-archive.zip')
-    expect(mocks.append.mock.calls).toHaveLength(2)
-    expect(mocks.pipe.mock.calls).toHaveLength(1)
-    expect(response._getStatusCode()).toEqual(200)
-  })
-})
-
-const getRandValueFromArray = arr => arr[Math.floor(Math.random() * arr.length)]
-
-const buildValidateFileParams = (fileType, mimetype) => {
-  const req = {
-    body: {
-      fileType,
-    },
-  }
-  const file = {
-    mimetype,
-  }
-  const cb = (p1, p2) => {
-    if (p2 === true) return true
-    return false
-  }
-
-  return [req, file, cb]
-}
diff --git a/packages/component-local-aws/src/middeware/upload.js b/packages/component-local-aws/src/middeware/upload.js
deleted file mode 100644
index f46f4176621cfb62e3cfec3598a3ae0219b588e2..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/middeware/upload.js
+++ /dev/null
@@ -1,53 +0,0 @@
-const Joi = require('joi')
-const uuid = require('uuid')
-const config = require('config')
-const multer = require('multer')
-const { get } = require('lodash')
-const multerS3 = require('multer-s3')
-
-const s3Config = get(config, 'pubsweet-component-aws-s3')
-const uploadValidations = require(s3Config.validations)
-
-const setupMulter = s3 => {
-  const upload = multer({
-    storage: multerS3({
-      s3,
-      bucket: s3Config.bucket,
-      contentType: (req, file, cb) => {
-        cb(null, file.mimetype)
-      },
-      metadata: (req, file, cb) => {
-        cb(null, {
-          FileType: get(req, 'body.fileType'),
-          FileName: get(file, 'originalname'),
-        })
-      },
-      key: (req, file, cb) => {
-        const fileKey = `${req.body.fragmentId}/${uuid.v4()}`
-        cb(null, fileKey)
-      },
-    }),
-    fileFilter: (req, file, cb) => validateFile(req, file, cb),
-  })
-
-  return upload
-}
-
-const validateFile = (req, file, cb) => {
-  const { fileType } = req.body
-  const { mimetype } = file
-
-  const valid = Joi.validate({ [fileType]: mimetype }, uploadValidations)
-
-  if (valid.error) {
-    req.fileValidationError = valid.error.message
-    return cb(null, false)
-  }
-
-  return cb(null, true)
-}
-
-module.exports = {
-  setupMulter,
-  validateFile,
-}
diff --git a/packages/component-local-aws/src/routeHandlers/deleteFile.js b/packages/component-local-aws/src/routeHandlers/deleteFile.js
deleted file mode 100644
index 9aa8974b76a053f0ea4229464c1f8ec9830c8fa3..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/routeHandlers/deleteFile.js
+++ /dev/null
@@ -1,22 +0,0 @@
-const { promisify } = require('util')
-const logger = require('@pubsweet/logger')
-
-const deleteFile = (s3, s3Config) => {
-  const asyncDeleteObject = promisify(s3.deleteObject.bind(s3))
-  return async (req, res) => {
-    const params = {
-      Bucket: s3Config.bucket,
-      Key: `${req.params.fragmentId}/${req.params.fileId}`,
-    }
-
-    try {
-      await asyncDeleteObject(params)
-      res.status(204)
-    } catch (err) {
-      logger.error(err.message)
-      res.status(err.statusCode).json({ error: err.message })
-    }
-  }
-}
-
-module.exports = deleteFile
diff --git a/packages/component-local-aws/src/routeHandlers/getSignedUrl.js b/packages/component-local-aws/src/routeHandlers/getSignedUrl.js
deleted file mode 100644
index edbad710242df2428920f69405c4313bd9f6c452..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/routeHandlers/getSignedUrl.js
+++ /dev/null
@@ -1,24 +0,0 @@
-const { promisify } = require('util')
-const logger = require('@pubsweet/logger')
-
-const getSignedUrl = (s3, s3Config) => {
-  const asyncGetSignedUrl = promisify(s3.getSignedUrl.bind(s3))
-  return async (req, res) => {
-    const params = {
-      Bucket: s3Config.bucket,
-      Key: `${req.params.fragmentId}/${req.params.fileId}`,
-    }
-
-    try {
-      const signedUrl = await asyncGetSignedUrl(params)
-      res.status(200).json({
-        signedUrl,
-      })
-    } catch (err) {
-      logger.error(err.message)
-      res.status(err.statusCode).json({ error: err.message })
-    }
-  }
-}
-
-module.exports = getSignedUrl
diff --git a/packages/component-local-aws/src/routeHandlers/postFile.js b/packages/component-local-aws/src/routeHandlers/postFile.js
deleted file mode 100644
index 228c78fed2d5914cf1134453255053d7524c63d0..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/routeHandlers/postFile.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const logger = require('@pubsweet/logger')
-
-module.exports = async (req, res) => {
-  if (req.fileValidationError !== undefined) {
-    logger.error(req.fileValidationError)
-    return res.status(400).json({ error: req.fileValidationError })
-  }
-  logger.debug(`${req.file.originalname} has been uploaded`)
-
-  return res.status(200).json({
-    id: req.file.key,
-    name: req.file.originalname,
-    size: req.file.size,
-  })
-}
diff --git a/packages/component-local-aws/src/routeHandlers/zipFiles.js b/packages/component-local-aws/src/routeHandlers/zipFiles.js
deleted file mode 100644
index 272eccbfb8e93b7a96b6c573259c047d613f0a06..0000000000000000000000000000000000000000
--- a/packages/component-local-aws/src/routeHandlers/zipFiles.js
+++ /dev/null
@@ -1,55 +0,0 @@
-const { get } = require('lodash')
-const { promisify } = require('util')
-const nodeArchiver = require('archiver')
-const logger = require('@pubsweet/logger')
-
-const zipFiles = (s3, s3Config, archiver = nodeArchiver) => {
-  const asyncGetObject = promisify(s3.getObject.bind(s3))
-  const asyncListObjects = promisify(s3.listObjects.bind(s3))
-  return async (req, res) => {
-    const { fragmentId } = req.params
-    try {
-      const params = {
-        Bucket: s3Config.bucket,
-        Prefix: `${fragmentId}`,
-      }
-      const s3Items = await asyncListObjects(params)
-
-      if (s3Items) {
-        const s3Files = await Promise.all(
-          s3Items.Contents.map(content =>
-            asyncGetObject({
-              Bucket: s3Config.bucket,
-              Key: content.Key,
-            }),
-          ),
-        )
-
-        if (s3Files) {
-          const archive = archiver('zip')
-          archive.pipe(res)
-          res.attachment(`${fragmentId}-archive.zip`)
-
-          s3Files.forEach(f => {
-            archive.append(f.Body, {
-              name: `${get(f, 'Metadata.filetype') || 'supplementary'}/${get(
-                f,
-                'Metadata.filename',
-              ) || f.ETag}`,
-            })
-          })
-          archive.finalize()
-        }
-      } else {
-        res.status(204).json({
-          message: `No files found for the requested manuscript.`,
-        })
-      }
-    } catch (err) {
-      logger.error(err.message)
-      res.status(err.statusCode).json({ error: err.message })
-    }
-  }
-}
-
-module.exports = zipFiles
diff --git a/packages/component-wizard/src/redux/conversion.js b/packages/component-wizard/src/redux/conversion.js
index b41a93f5d376e38a42425b6d54db367fc67d898b..a290931bb5c244bf166523909cf1c2a1fa3cb228 100644
--- a/packages/component-wizard/src/redux/conversion.js
+++ b/packages/component-wizard/src/redux/conversion.js
@@ -69,7 +69,7 @@ export const createDraftSubmission = history => (dispatch, getState) => {
       // redirect after a short delay
       window.setTimeout(() => {
         history.push(route)
-      }, 1000)
+      }, 10)
     })
   })
 }
diff --git a/packages/components-faraday/src/components/Admin/AddEditUser.js b/packages/components-faraday/src/components/Admin/AddEditUser.js
index fa5a61a9b74dcd7775b08038897a0cb894f07227..45454fbd8e06f202d4776d3ad3f6c51c68cad6d7 100644
--- a/packages/components-faraday/src/components/Admin/AddEditUser.js
+++ b/packages/components-faraday/src/components/Admin/AddEditUser.js
@@ -19,13 +19,13 @@ const onSubmit = (values, dispatch, { isEdit, history }) => {
   if (!isEdit) {
     const newValues = setAdmin(values)
     return create('/users/invite', newValues)
-      .then(r => history.push('/admin/users'))
+      .then(() => history.push('/admin/users'))
       .catch(error => {
         const err = get(error, 'response')
         if (err) {
           const errorMessage = get(JSON.parse(err), 'error')
           throw new SubmissionError({
-            email: errorMessage || 'Something went wrong',
+            _error: errorMessage || 'Something went wrong',
           })
         }
       })
@@ -40,23 +40,35 @@ const onSubmit = (values, dispatch, { isEdit, history }) => {
       if (err) {
         const errorMessage = get(JSON.parse(err), 'error')
         throw new SubmissionError({
-          roles: errorMessage || 'Something went wrong',
+          _error: errorMessage || 'Something went wrong',
         })
       }
     })
 }
 
-const AddEditUser = ({ handleSubmit, journal, isEdit, user, history }) => (
+const AddEditUser = ({
+  handleSubmit,
+  journal,
+  isEdit,
+  user,
+  history,
+  error,
+}) => (
   <Root>
     <FormContainer onSubmit={handleSubmit}>
       {isEdit ? (
         <EditUserForm
+          error={error}
           journal={journal}
           roles={getRoleOptions(journal)}
           user={user}
         />
       ) : (
-        <AddUserForm journal={journal} roles={getRoleOptions(journal)} />
+        <AddUserForm
+          error={error}
+          journal={journal}
+          roles={getRoleOptions(journal)}
+        />
       )}
       <Row>
         <Button onClick={history.goBack}>Back</Button>
diff --git a/packages/components-faraday/src/components/Admin/AddUserForm.js b/packages/components-faraday/src/components/Admin/AddUserForm.js
index 4317c2c4fbd0d4444bc9be8d203c86726670a388..df8e96e0561b86d1748a70932322d396b0c5668b 100644
--- a/packages/components-faraday/src/components/Admin/AddUserForm.js
+++ b/packages/components-faraday/src/components/Admin/AddUserForm.js
@@ -1,10 +1,17 @@
 import React from 'react'
 import styled from 'styled-components'
-import { ValidatedField, TextField, Menu } from '@pubsweet/ui'
+import { ValidatedField, TextField, Menu, th } from '@pubsweet/ui'
 
 import { required } from 'xpub-validators'
 
-const AddUserForm = ({ roles, journal }) => {
+const emailRegex = new RegExp(
+  /^(([^<>()\[\]\.,;:\s@\"]+(\.[^<>()\[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i, //eslint-disable-line
+)
+
+const emailValidator = value =>
+  emailRegex.test(value) ? undefined : 'Invalid email'
+
+const AddUserForm = ({ roles, journal, error }) => {
   const roleOptions = roles.filter(r =>
     ['editorInChief', 'author', 'admin'].includes(r.value),
   )
@@ -17,10 +24,10 @@ const AddUserForm = ({ roles, journal }) => {
           <ValidatedField
             component={TextField}
             name="email"
-            validate={[required]}
+            validate={[emailValidator]}
           />
         </RowItem>
-        <RowItem>
+        <RowItem data-test="role-selector">
           <Label> Role*</Label>
           <ValidatedField
             component={input => <Menu {...input} options={roleOptions} />}
@@ -44,7 +51,7 @@ const AddUserForm = ({ roles, journal }) => {
           <Label> Affiliation </Label>
           <ValidatedField component={TextField} name="affiliation" />
         </RowItem>
-        <RowItem>
+        <RowItem data-test="title-selector">
           <Label> Title </Label>
           <ValidatedField
             component={input => <Menu {...input} options={journal.title} />}
@@ -52,6 +59,9 @@ const AddUserForm = ({ roles, journal }) => {
           />
         </RowItem>
       </Row>
+      <Row>
+        <RowItem>{error && <ErrorMessage>{error}</ErrorMessage>}</RowItem>
+      </Row>
     </div>
   )
 }
@@ -63,22 +73,27 @@ export default AddUserForm
 const Row = styled.div`
   display: flex;
   flex-direction: row;
-  margin: 20px 0;
+  margin: calc(${th('subGridUnit')}*3) 0;
 `
 
 const RowItem = styled.div`
   flex: 1;
-  margin-right: 20px;
+  margin-right: calc(${th('subGridUnit')}*3);
 `
 
 const Title = styled.h4`
-  font-size: ${({ theme }) => theme.fontSizeHeading4};
-  color: ${({ theme }) => theme.colorPrimary};
-  margin: 10px 0;
+  font-size: ${th('fontSizeHeading4')};
+  color: ${th('colorPrimary')};
+  margin: calc(${th('subGridUnit')}*2) 0;
 `
 
 const Label = styled.div`
-  font-size: ${({ theme }) => theme.fontSizeBase};
+  font-size: ${th('fontSizeBase')};
   text-transform: uppercase;
 `
+
+const ErrorMessage = styled.div`
+  color: ${th('colorError')};
+`
+
 // #endregion
diff --git a/packages/components-faraday/src/components/Admin/AdminDashboard.js b/packages/components-faraday/src/components/Admin/AdminDashboard.js
index b36d692ea13982415d60c8355ff33d8293b159c8..5b138406023bf787f602ed026686d3e47d32a5fe 100644
--- a/packages/components-faraday/src/components/Admin/AdminDashboard.js
+++ b/packages/components-faraday/src/components/Admin/AdminDashboard.js
@@ -12,7 +12,7 @@ const AdminDashboard = ({ history, theme }) => (
         </Icon>
         <span>Journal configuration</span>
       </Card>
-      <Card onClick={() => history.push('/admin/users')}>
+      <Card data-test="card-users" onClick={() => history.push('/admin/users')}>
         <Icon color={theme.colorPrimary} size={6}>
           users
         </Icon>
diff --git a/packages/components-faraday/src/components/Admin/AdminUsers.js b/packages/components-faraday/src/components/Admin/AdminUsers.js
index 01fcf26ab469c26c4c9d3b9aec37118554f613cc..4185c022c7a6c704fdacb35f20039c4d29690789 100644
--- a/packages/components-faraday/src/components/Admin/AdminUsers.js
+++ b/packages/components-faraday/src/components/Admin/AdminUsers.js
@@ -1,5 +1,5 @@
 import React from 'react'
-import { get } from 'lodash'
+import { get, isEqual } from 'lodash'
 import { connect } from 'react-redux'
 import styled, { withTheme } from 'styled-components'
 import { Icon, Menu, th } from '@pubsweet/ui'
@@ -23,6 +23,8 @@ const TableRow = ({
   lastName = '',
   affiliation,
   isConfirmed,
+  editorInChief,
+  admin,
   roleOptions,
 }) => (
   <Row>
@@ -33,12 +35,9 @@ const TableRow = ({
     <td>{`${firstName} ${lastName}`}</td>
     <td>{affiliation}</td>
     <td>
-      {roles &&
-        roles.map((r, i, arr) => (
-          <Role key={r}>{`${roleOptions[r]}${
-            i !== arr.length - 1 ? ', ' : ''
-          }`}</Role>
-        ))}
+      <Role>{`Author${isEqual(editorInChief, true) ? ', Editor in Chief' : ''}${
+        isEqual(admin, true) ? ', Admin' : ''
+      }`}</Role>
     </td>
     <td>
       <Tag>{isConfirmed ? 'Confirmed' : 'Invited'}</Tag>
@@ -72,7 +71,10 @@ const Users = ({
           <span>Admin Dashboard</span>
           <span>Users</span>
         </BreadCrumbs>
-        <AddButton onClick={() => history.push('/admin/users/add')}>
+        <AddButton
+          data-test="button-add-user"
+          onClick={() => history.push('/admin/users/add')}
+        >
           <Icon color={theme.colorPrimary} size={3}>
             plus-circle
           </Icon>
@@ -129,7 +131,7 @@ const Users = ({
             <td>Email</td>
             <td>Full name</td>
             <td>Affiliation</td>
-            <td width="200">Roles</td>
+            <td width="220">Roles</td>
             <td>Status</td>
             <td width="50" />
           </tr>
@@ -297,12 +299,12 @@ const Tag = styled.span`
   margin-right: calc(${th('subGridUnit')});
 `
 
-const Role = styled.span`
-  height: 17px;
+const Role = styled.div`
   font-size: ${th('fontSizeBaseSmall')};
   text-align: left;
   color: ${th('colorPrimary')};
   text-transform: uppercase;
+  line-height: 1.5;
 `
 
 const Action = styled(Link)`
diff --git a/packages/components-faraday/src/components/Admin/EditUserForm.js b/packages/components-faraday/src/components/Admin/EditUserForm.js
index 1f908b0a589e2c1b32d9d7e36a107511355a84c0..ecbef0d9aff2bc5ad41ab4706a3da6cf313e5d95 100644
--- a/packages/components-faraday/src/components/Admin/EditUserForm.js
+++ b/packages/components-faraday/src/components/Admin/EditUserForm.js
@@ -1,66 +1,92 @@
 import React from 'react'
 import styled from 'styled-components'
-import { ValidatedField, TextField, Menu, CheckboxGroup } from '@pubsweet/ui'
+import { ValidatedField, TextField, Menu, Checkbox, th } from '@pubsweet/ui'
 
 import { required } from 'xpub-validators'
 
-const EditUserForm = ({ roles, journal, user }) => {
-  const roleOptions = roles.filter(r =>
-    ['editorInChief', 'author', 'admin'].includes(r.value),
-  )
-  return (
-    <div>
-      <Title>Edit user</Title>
-      <Subtitle>{user.email}</Subtitle>
-      <Row>
-        <RowItem>
-          <Label> First name* </Label>
-          <ValidatedField
-            component={TextField}
-            name="firstName"
-            validate={[required]}
-          />
-        </RowItem>
-        <RowItem>
-          <Label> Last name* </Label>
-          <ValidatedField
-            component={TextField}
-            name="lastName"
-            validate={[required]}
-          />
-        </RowItem>
-      </Row>
-      <Row>
-        <RowItem>
-          <Label> Affiliation* </Label>
-          <ValidatedField
-            component={TextField}
-            name="affiliation"
-            validate={[required]}
-          />
-        </RowItem>
-        <RowItem>
-          <Label> Title* </Label>
-          <ValidatedField
-            component={input => <Menu {...input} options={journal.title} />}
-            name="title"
-          />
-        </RowItem>
-      </Row>
-      <Row>
-        <RowItem>
-          <Label> Roles*</Label>
-          <ValidatedField
-            component={input => (
-              <CheckboxGroup {...input} options={roleOptions} />
-            )}
-            name="roles"
-          />
-        </RowItem>
-      </Row>
-    </div>
-  )
-}
+const EditUserForm = ({ roles, journal, user, error }) => (
+  <div>
+    <Title>Edit user</Title>
+    <Subtitle>{user.email}</Subtitle>
+    <Row>
+      <RowItem>
+        <Label> First name* </Label>
+        <ValidatedField
+          component={TextField}
+          name="firstName"
+          validate={[required]}
+        />
+      </RowItem>
+      <RowItem>
+        <Label> Last name* </Label>
+        <ValidatedField
+          component={TextField}
+          name="lastName"
+          validate={[required]}
+        />
+      </RowItem>
+    </Row>
+    <Row>
+      <RowItem>
+        <Label> Affiliation* </Label>
+        <ValidatedField
+          component={TextField}
+          name="affiliation"
+          validate={[required]}
+        />
+      </RowItem>
+      <RowItem>
+        <Label> Title* </Label>
+        <ValidatedField
+          component={input => <Menu {...input} options={journal.title} />}
+          name="title"
+        />
+      </RowItem>
+    </Row>
+    <Row>
+      <RowItem>
+        <Label> Roles*</Label>
+        <ValidatedField
+          component={input => (
+            <Checkbox
+              checked
+              readonly
+              type="checkbox"
+              {...input}
+              label="Author"
+            />
+          )}
+          name="author"
+        />
+        <ValidatedField
+          component={input => (
+            <Checkbox
+              checked={input.value}
+              type="checkbox"
+              {...input}
+              label="Editor in Chief"
+            />
+          )}
+          name="editorInChief"
+        />
+        <ValidatedField
+          component={input => (
+            <Checkbox
+              checked={input.value}
+              type="checkbox"
+              {...input}
+              label="Admin"
+            />
+          )}
+          name="admin"
+        />
+      </RowItem>
+    </Row>
+    <Row>
+      <RowItem>{error && <ErrorMessage>{error}</ErrorMessage>}</RowItem>
+    </Row>
+  </div>
+)
 
 export default EditUserForm
 
@@ -69,29 +95,33 @@ export default EditUserForm
 const Row = styled.div`
   display: flex;
   flex-direction: row;
-  margin: 20px 0;
-  background-color: ${({ theme }) => theme.backgroundColorReverse};
+  margin: calc(${th('subGridUnit')}*3) 0;
+  background-color: ${th('backgroundColorReverse')};
 `
 
 const RowItem = styled.div`
   flex: 1;
-  margin-right: 20px;
+  margin-right: calc(${th('subGridUnit')}*3);
 `
 
 const Title = styled.h4`
-  font-size: ${({ theme }) => theme.fontSizeHeading4};
-  color: ${({ theme }) => theme.colorPrimary};
-  margin: 10px 0;
+  font-size: ${th('fontSizeHeading4')};
+  color: ${th('colorPrimary')};
+  margin: calc(${th('subGridUnit')}*2) 0;
 `
 
 const Subtitle = styled.div`
-  font-size: ${({ theme }) => theme.fontSizeBase};
-  color: ${({ theme }) => theme.colorPrimary};
+  font-size: ${th('fontSizeBase')};
+  color: ${th('colorPrimary')};
   margin: 0;
 `
 
 const Label = styled.div`
-  font-size: ${({ theme }) => theme.fontSizeBase};
+  font-size: ${th('fontSizeBase')};
   text-transform: uppercase;
 `
+const ErrorMessage = styled.div`
+  color: ${th('colorError')};
+`
+
 // #endregion
diff --git a/packages/components-faraday/src/components/Admin/utils.js b/packages/components-faraday/src/components/Admin/utils.js
index de7049e4123d0e4ef6ef174a757da7024a4fae50..18d68678757f353480e592d49f094e0e98129b11 100644
--- a/packages/components-faraday/src/components/Admin/utils.js
+++ b/packages/components-faraday/src/components/Admin/utils.js
@@ -23,8 +23,8 @@ export const parseUpdateUser = values => {
     'title',
     'roles',
     'rev',
+    'editorInChief',
   ]
 
-  const newValues = setAdmin(values)
-  return pick(newValues, valuesToSave)
+  return pick(values, valuesToSave)
 }
diff --git a/packages/components-faraday/src/components/AuthorList/AuthorAdder.js b/packages/components-faraday/src/components/AuthorList/AuthorAdder.js
index 2cb1d3258fbd47afa1004fa0fb6af36b29a46314..aef24acfa0d5657ceebb00eaf8bbc2f03b915895 100644
--- a/packages/components-faraday/src/components/AuthorList/AuthorAdder.js
+++ b/packages/components-faraday/src/components/AuthorList/AuthorAdder.js
@@ -110,9 +110,11 @@ export default compose(
         fragmentId,
       ).then(author => {
         const newAuthors = [...authors, author]
-        setFormAuthors(newAuthors)
-        reset()
         setEditMode(false)()
+        setTimeout(() => {
+          setFormAuthors(newAuthors)
+        }, 1000)
+        reset()
       })
     },
   }),
diff --git a/packages/components-faraday/src/components/SignUp/SignUpInvitationForm.js b/packages/components-faraday/src/components/SignUp/SignUpInvitationForm.js
index 007ee79b890e6de705d5b8e1946d2311682920ed..6337b777a46e2fc6c42d694799bdee42972ce38c 100644
--- a/packages/components-faraday/src/components/SignUp/SignUpInvitationForm.js
+++ b/packages/components-faraday/src/components/SignUp/SignUpInvitationForm.js
@@ -24,6 +24,7 @@ const SignUpInvitation = ({
     {error && <Err>Token expired or Something went wrong.</Err>}
     {step === 0 && (
       <Step0
+        error={error}
         initialValues={initialValues}
         journal={journal}
         onSubmit={nextStep}
@@ -31,6 +32,7 @@ const SignUpInvitation = ({
     )}
     {step === 1 && (
       <Step1
+        error={error}
         initialValues={initialValues}
         journal={journal}
         onSubmit={submitConfirmation}
diff --git a/packages/components-faraday/src/components/SignUp/SignUpInvitationPage.js b/packages/components-faraday/src/components/SignUp/SignUpInvitationPage.js
index 6dcd11f46d9ed9d331c718c5a52d37e22095102f..5699888919716ae1dca12dc72f1984ac073be373 100644
--- a/packages/components-faraday/src/components/SignUp/SignUpInvitationPage.js
+++ b/packages/components-faraday/src/components/SignUp/SignUpInvitationPage.js
@@ -42,7 +42,7 @@ const confirmUser = (email, token, history) => (values, dispatch) => {
         if (err) {
           const errorMessage = get(JSON.parse(err), 'error')
           throw new SubmissionError({
-            password: errorMessage || 'Something went wrong',
+            _error: errorMessage || 'Something went wrong',
           })
         }
       })
diff --git a/packages/components-faraday/src/components/SignUp/SignUpStep0.js b/packages/components-faraday/src/components/SignUp/SignUpStep0.js
index e14fd717c1e26caece81c55f4061bc8904e7061f..2fb7bb2fd62e2331474c866ec81d46dfabc27457 100644
--- a/packages/components-faraday/src/components/SignUp/SignUpStep0.js
+++ b/packages/components-faraday/src/components/SignUp/SignUpStep0.js
@@ -5,7 +5,7 @@ import { isUndefined } from 'lodash'
 import { required } from 'xpub-validators'
 import { Button, ValidatedField, TextField, Menu } from '@pubsweet/ui'
 
-const Step0 = ({ journal, handleSubmit, initialValues }) =>
+const Step0 = ({ journal, handleSubmit, initialValues, error }) =>
   !isUndefined(initialValues) ? (
     <FormContainer onSubmit={handleSubmit}>
       <Row>
@@ -18,23 +18,24 @@ const Step0 = ({ journal, handleSubmit, initialValues }) =>
           />
         </RowItem>
         <RowItem>
-          <Label> Affiliation* </Label>
+          <Label> Last name* </Label>
           <ValidatedField
             component={TextField}
-            name="affiliation"
+            name="lastName"
             validate={[required]}
           />
         </RowItem>
       </Row>
       <Row>
         <RowItem>
-          <Label> Last name* </Label>
+          <Label> Affiliation* </Label>
           <ValidatedField
             component={TextField}
-            name="lastName"
+            name="affiliation"
             validate={[required]}
           />
         </RowItem>
+
         <RowItem>
           <Label> Title* </Label>
           <ValidatedField
@@ -51,7 +52,7 @@ const Step0 = ({ journal, handleSubmit, initialValues }) =>
       </Row>
     </FormContainer>
   ) : (
-    <div>Loading...</div>
+    <div>{!isUndefined(error) && 'Loading...'}</div>
   )
 
 export default reduxForm({
diff --git a/packages/components-faraday/src/components/SignUp/SignUpStep1.js b/packages/components-faraday/src/components/SignUp/SignUpStep1.js
index 7109f6c581422a6499788836fa9b40df01988acd..260aa47d1854ca5ceb793cceb0d3e2ba43a648e8 100644
--- a/packages/components-faraday/src/components/SignUp/SignUpStep1.js
+++ b/packages/components-faraday/src/components/SignUp/SignUpStep1.js
@@ -2,9 +2,9 @@ import React from 'react'
 import styled from 'styled-components'
 import { reduxForm } from 'redux-form'
 import { required } from 'xpub-validators'
-import { Button, ValidatedField, TextField } from '@pubsweet/ui'
+import { Button, ValidatedField, TextField, th } from '@pubsweet/ui'
 
-const Step1 = ({ journal, handleSubmit }) => (
+const Step1 = ({ journal, handleSubmit, error }) => (
   <FormContainer onSubmit={handleSubmit}>
     <Row>
       <RowItem>
@@ -16,6 +16,13 @@ const Step1 = ({ journal, handleSubmit }) => (
         />
       </RowItem>
     </Row>
+    {error && (
+      <Row>
+        <RowItem>
+          <Err>{error}</Err>
+        </RowItem>
+      </Row>
+    )}
     <Row>
       <Button primary type="submit">
         CONFIRM
@@ -35,18 +42,23 @@ const FormContainer = styled.form``
 const Row = styled.div`
   display: flex;
   flex-direction: row;
-  margin: 20px 0;
+  margin: ${th('gridUnit')} 0;
   align-items: center;
   justify-content: space-evenly;
 `
 
 const RowItem = styled.div`
   flex: 1;
-  margin-right: 20px;
+  margin-right: ${th('gridUnit')};
 `
 
 const Label = styled.div`
-  font-size: ${({ theme }) => theme.fontSizeBaseSmall};
-  font-family: ${({ theme }) => theme.fontReading};
+  font-size: ${th('fontSizeBaseSmall')};
+  font-family: ${th('fontReading')};
   text-transform: uppercase;
 `
+const Err = styled.div`
+  color: ${th('colorError')};
+  text-align: left;
+  margin-top: calc(${th('gridUnit')}*-1);
+`
diff --git a/packages/components-faraday/src/redux/authors.js b/packages/components-faraday/src/redux/authors.js
index c9a863d768a3efe1a824667ef4e8f52528c0a859..a4219d6ae9872ef33d02364f2371bc01531bc1bd 100644
--- a/packages/components-faraday/src/redux/authors.js
+++ b/packages/components-faraday/src/redux/authors.js
@@ -1,5 +1,4 @@
 import { get } from 'lodash'
-import * as api from 'pubsweet-client/src/helpers/api'
 
 // constants
 const REQUEST = 'authors/REQUEST'
@@ -20,19 +19,8 @@ export const authorSuccess = () => ({
   type: SUCCESS,
 })
 
-export const addAuthor = (author, collectionId, fragmentId) => dispatch => {
-  dispatch(authorRequest())
-  return api
-    .create(
-      `/collections/${collectionId}/fragments/${fragmentId}/authors`,
-      author,
-    )
-    .then(author => {
-      dispatch(authorSuccess())
-      return author
-    })
-    .catch(err => dispatch(authorFaiure(err)))
-}
+export const addAuthor = (author, collectionId, fragmentId) => dispatch =>
+  Promise.resolve(author)
 
 // selectors
 export const getFragmentAuthors = (state, fragmentId) =>
diff --git a/packages/xpub-faraday/app/config/journal/submit-wizard.js b/packages/xpub-faraday/app/config/journal/submit-wizard.js
index 5f3ff6b7461f3526f7c487009da1b8b02d0d5e61..ab50d4ab1c3067a9977febbb0ae7444d80880189 100644
--- a/packages/xpub-faraday/app/config/journal/submit-wizard.js
+++ b/packages/xpub-faraday/app/config/journal/submit-wizard.js
@@ -1,9 +1,7 @@
 import React from 'react'
 import styled from 'styled-components'
 import uploadFileFn from 'xpub-upload'
-// TODO: Add back abstract when xpub-edit is published
-// import { AbstractEditor, TitleEditor } from 'xpub-edit'
-import { TitleEditor } from 'xpub-edit'
+import { AbstractEditor, TitleEditor } from 'xpub-edit'
 import { Menu, YesOrNo, TextField, CheckboxGroup } from '@pubsweet/ui'
 import { required, minChars, minSize } from 'xpub-validators'
 import { AuthorList, Files } from 'pubsweet-components-faraday/src/components'
@@ -140,7 +138,7 @@ export default {
         },
         {
           fieldId: 'metadata.abstract',
-          renderComponent: TitleEditor,
+          renderComponent: AbstractEditor,
           title: 'Abstract',
           placeholder: 'Write an abstract',
           validate: [requiredBasedOnType],
diff --git a/packages/xpub-faraday/app/config/journal/wizard-validators.js b/packages/xpub-faraday/app/config/journal/wizard-validators.js
index 8504e61f02765ae8e83a9f2f43063801258e2d10..bec3371d1699e67c3ef81688f26205bee7328b46 100644
--- a/packages/xpub-faraday/app/config/journal/wizard-validators.js
+++ b/packages/xpub-faraday/app/config/journal/wizard-validators.js
@@ -30,9 +30,9 @@ export const editModeEnabled = value => {
   return undefined
 }
 
-export const requiredFiles = (valus, formValues) => {
+export const requiredFiles = (values, formValues) => {
   const manuscripts = get(formValues, 'files.manuscripts')
-  if (manuscripts && manuscripts.length === 0) {
+  if (!manuscripts || manuscripts.length === 0) {
     return 'At least one main manuscript file is needed.'
   }
   return undefined
diff --git a/packages/xpub-faraday/config/components.json b/packages/xpub-faraday/config/components.json
index 7a1555ce9bc5d36ac95e3eca4e33f466e66511e4..4f60ab58b80cd788c524e30b0cce9b010c05fe7a 100644
--- a/packages/xpub-faraday/config/components.json
+++ b/packages/xpub-faraday/config/components.json
@@ -6,7 +6,5 @@
   "pubsweet-component-modal",
   "pubsweet-components-faraday",
   "@pubsweet/component-aws-s3",
-  "pubsweet-component-invite",
-  "component-aws-download",
-  "component-local-aws"
+  "pubsweet-component-invite"
 ]
diff --git a/packages/xpub-faraday/package.json b/packages/xpub-faraday/package.json
index ea94799bfadc6b0d79c9ceff8afbd55d0ba0ad62..177fd1eb708fc8cc9d7dde29c095fcb5a872061e 100644
--- a/packages/xpub-faraday/package.json
+++ b/packages/xpub-faraday/package.json
@@ -8,8 +8,8 @@
     "url": "https://gitlab.coko.foundation/xpub/xpub-faraday"
   },
   "dependencies": {
-    "@pubsweet/component-aws-s3": "^0.1.1",
-    "@pubsweet/ui": "^3.0.0",
+    "@pubsweet/ui": "^3.2.0",
+    "@pubsweet/component-aws-s3": "^1.0.0",
     "aws-sdk": "^2.197.0",
     "babel-core": "^6.26.0",
     "config": "^1.26.2",
@@ -42,7 +42,8 @@
     "typeface-ubuntu-mono": "^0.0.54",
     "winston": "^2.4.0",
     "xpub-connect": "^0.0.3",
-    "xpub-edit": "^0.0.3",
+    "xpub-edit": "^0.0.4",
+    "xpub-faraday-server": "^0.0.1",
     "xpub-journal": "^0.0.3",
     "xpub-selectors": "^0.0.3",
     "xpub-styleguide": "^0.0.3",
diff --git a/yarn.lock b/yarn.lock
index 85ae4cc4c525ed3719b948afa6bd8be99f92df01..8ffb522b4d849f6b522ee7d55e86bb0a682a39e8 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -78,10 +78,11 @@
     lodash "^4.2.0"
     to-fast-properties "^2.0.0"
 
-"@pubsweet/component-aws-s3@^0.1.1":
-  version "0.1.1"
-  resolved "https://registry.yarnpkg.com/@pubsweet/component-aws-s3/-/component-aws-s3-0.1.1.tgz#2faa379c1b8c12dbc6573a5627b09f536a484cc3"
+"@pubsweet/component-aws-s3@^1.0.0":
+  version "1.0.0"
+  resolved "https://registry.yarnpkg.com/@pubsweet/component-aws-s3/-/component-aws-s3-1.0.0.tgz#5cb1715709ba5ad7b8ad79d1ef42d6818d17ca3e"
   dependencies:
+    archiver "^2.1.1"
     aws-sdk "^2.185.0"
     body-parser "^1.17.2"
     multer "^1.3.0"
@@ -171,7 +172,7 @@
     redux-form "^7.0.3"
     styled-components "^2.4.0"
 
-"@pubsweet/ui@^3.0.0", "@pubsweet/ui@^3.1.0":
+"@pubsweet/ui@^3.1.0":
   version "3.1.0"
   resolved "https://registry.yarnpkg.com/@pubsweet/ui/-/ui-3.1.0.tgz#24c25c29fc36e34b9f654fe4378502232f8204fa"
   dependencies:
@@ -193,6 +194,28 @@
     redux-form "^7.0.3"
     styled-components "^2.4.0"
 
+"@pubsweet/ui@^3.2.0":
+  version "3.2.0"
+  resolved "https://registry.yarnpkg.com/@pubsweet/ui/-/ui-3.2.0.tgz#b787f1bb53fa818aade863c221bf47e2929e669e"
+  dependencies:
+    babel-jest "^21.2.0"
+    classnames "^2.2.5"
+    enzyme "^3.2.0"
+    enzyme-adapter-react-16 "^1.1.1"
+    humps "^2.0.1"
+    lodash "^4.17.4"
+    prop-types "^15.5.10"
+    react "^16.2.0"
+    react-dom "^16.2.0"
+    react-feather "^1.0.8"
+    react-redux "^5.0.2"
+    react-router-dom "^4.2.2"
+    react-tag-autocomplete "^5.5.0"
+    recompose "^0.26.0"
+    redux "^3.6.0"
+    redux-form "^7.0.3"
+    styled-components "^2.4.0"
+
 "@types/node@*":
   version "9.4.6"
   resolved "https://registry.yarnpkg.com/@types/node/-/node-9.4.6.tgz#d8176d864ee48753d053783e4e463aec86b8d82e"
@@ -3034,7 +3057,19 @@ enzyme-adapter-react-15@^1.0.5:
     object.values "^1.0.4"
     prop-types "^15.5.10"
 
-enzyme-adapter-utils@^1.1.0:
+enzyme-adapter-react-16@^1.1.1:
+  version "1.1.1"
+  resolved "https://registry.yarnpkg.com/enzyme-adapter-react-16/-/enzyme-adapter-react-16-1.1.1.tgz#a8f4278b47e082fbca14f5bfb1ee50ee650717b4"
+  dependencies:
+    enzyme-adapter-utils "^1.3.0"
+    lodash "^4.17.4"
+    object.assign "^4.0.4"
+    object.values "^1.0.4"
+    prop-types "^15.6.0"
+    react-reconciler "^0.7.0"
+    react-test-renderer "^16.0.0-0"
+
+enzyme-adapter-utils@^1.1.0, enzyme-adapter-utils@^1.3.0:
   version "1.3.0"
   resolved "https://registry.yarnpkg.com/enzyme-adapter-utils/-/enzyme-adapter-utils-1.3.0.tgz#d6c85756826c257a8544d362cc7a67e97ea698c7"
   dependencies:
@@ -7686,6 +7721,15 @@ react-proxy@^3.0.0-alpha.0:
   dependencies:
     lodash "^4.6.1"
 
+react-reconciler@^0.7.0:
+  version "0.7.0"
+  resolved "https://registry.yarnpkg.com/react-reconciler/-/react-reconciler-0.7.0.tgz#9614894103e5f138deeeb5eabaf3ee80eb1d026d"
+  dependencies:
+    fbjs "^0.8.16"
+    loose-envify "^1.1.0"
+    object-assign "^4.1.1"
+    prop-types "^15.6.0"
+
 react-redux@^5.0.2, react-redux@^5.0.6, react-redux@^5.0.7:
   version "5.0.7"
   resolved "https://registry.yarnpkg.com/react-redux/-/react-redux-5.0.7.tgz#0dc1076d9afb4670f993ffaef44b8f8c1155a4c8"
@@ -7728,10 +7772,18 @@ react-router@^4.2.0:
     prop-types "^15.5.4"
     warning "^3.0.0"
 
-react-tag-autocomplete@^5.4.1:
+react-tag-autocomplete@^5.4.1, react-tag-autocomplete@^5.5.0:
   version "5.5.0"
   resolved "https://registry.yarnpkg.com/react-tag-autocomplete/-/react-tag-autocomplete-5.5.0.tgz#49841388b88323f6bccb0c10039bd0252875b49f"
 
+react-test-renderer@^16.0.0-0:
+  version "16.2.0"
+  resolved "https://registry.yarnpkg.com/react-test-renderer/-/react-test-renderer-16.2.0.tgz#bddf259a6b8fcd8555f012afc8eacc238872a211"
+  dependencies:
+    fbjs "^0.8.16"
+    object-assign "^4.1.1"
+    prop-types "^15.6.0"
+
 react-transition-group@^2.0.0, react-transition-group@^2.2.0:
   version "2.2.1"
   resolved "https://registry.yarnpkg.com/react-transition-group/-/react-transition-group-2.2.1.tgz#e9fb677b79e6455fd391b03823afe84849df4a10"
@@ -9835,11 +9887,11 @@ xpub-connect@^0.0.3:
     redux "^3.6.0"
     styled-components "^2.4.0"
 
-xpub-edit@^0.0.3:
-  version "0.0.3"
-  resolved "https://registry.yarnpkg.com/xpub-edit/-/xpub-edit-0.0.3.tgz#76947a18140d1b61c460fcd96127569d322e0da7"
+xpub-edit@^0.0.4:
+  version "0.0.4"
+  resolved "https://registry.yarnpkg.com/xpub-edit/-/xpub-edit-0.0.4.tgz#2d20d4ab0ba83ac0b4b3d3f273a74da1518b55d1"
   dependencies:
-    "@pubsweet/ui" "3.0.0"
+    "@pubsweet/ui" "^3.2.0"
     prosemirror-commands "^1.0.1"
     prosemirror-dropcursor "^1.0.0"
     prosemirror-gapcursor "^1.0.0"
@@ -9849,8 +9901,6 @@ xpub-edit@^0.0.3:
     prosemirror-model "^1.0.0"
     prosemirror-state "^1.0.1"
     prosemirror-view "^1.0.0"
-    react "^16.2.0"
-    react-dom "^16.2.0"
 
 xpub-journal@^0.0.3:
   version "0.0.3"