@payloadcms/next 3.0.0-beta.55 → 3.0.0-beta.57

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (135) hide show
  1. package/dist/elements/DocumentHeader/Tabs/Tab/index.scss +91 -0
  2. package/dist/elements/DocumentHeader/Tabs/index.scss +53 -0
  3. package/dist/elements/DocumentHeader/index.scss +51 -0
  4. package/dist/elements/LeaveWithoutSaving/index.scss +36 -0
  5. package/dist/elements/Nav/NavWrapper/index.scss +17 -0
  6. package/dist/elements/Nav/index.scss +150 -0
  7. package/dist/prod/index.js +2 -2
  8. package/dist/prod/styles.css +1 -1
  9. package/dist/routes/graphql/handler.d.ts.map +1 -1
  10. package/dist/routes/graphql/handler.js +11 -11
  11. package/dist/routes/graphql/handler.js.map +1 -1
  12. package/dist/routes/rest/auth/forgotPassword.d.ts.map +1 -1
  13. package/dist/routes/rest/auth/forgotPassword.js +7 -3
  14. package/dist/routes/rest/auth/forgotPassword.js.map +1 -1
  15. package/dist/routes/rest/auth/login.d.ts.map +1 -1
  16. package/dist/routes/rest/auth/login.js +9 -4
  17. package/dist/routes/rest/auth/login.js.map +1 -1
  18. package/dist/routes/rest/auth/refresh.d.ts.map +1 -1
  19. package/dist/routes/rest/auth/refresh.js +12 -20
  20. package/dist/routes/rest/auth/refresh.js.map +1 -1
  21. package/dist/routes/rest/auth/registerFirstUser.d.ts.map +1 -1
  22. package/dist/routes/rest/auth/registerFirstUser.js +9 -2
  23. package/dist/routes/rest/auth/registerFirstUser.js.map +1 -1
  24. package/dist/routes/rest/auth/verifyEmail.js +1 -1
  25. package/dist/routes/rest/auth/verifyEmail.js.map +1 -1
  26. package/dist/routes/rest/buildFormState.d.ts +2 -2
  27. package/dist/routes/rest/buildFormState.d.ts.map +1 -1
  28. package/dist/routes/rest/buildFormState.js.map +1 -1
  29. package/dist/routes/rest/files/checkFileAccess.d.ts +2 -2
  30. package/dist/routes/rest/files/checkFileAccess.d.ts.map +1 -1
  31. package/dist/routes/rest/files/checkFileAccess.js.map +1 -1
  32. package/dist/routes/rest/files/getFile.d.ts +2 -2
  33. package/dist/routes/rest/files/getFile.d.ts.map +1 -1
  34. package/dist/routes/rest/files/getFile.js.map +1 -1
  35. package/dist/routes/rest/index.d.ts.map +1 -1
  36. package/dist/routes/rest/index.js +88 -93
  37. package/dist/routes/rest/index.js.map +1 -1
  38. package/dist/routes/rest/og/index.d.ts +2 -2
  39. package/dist/routes/rest/og/index.d.ts.map +1 -1
  40. package/dist/routes/rest/og/index.js.map +1 -1
  41. package/dist/routes/rest/og/roboto-regular.woff +0 -0
  42. package/dist/routes/rest/routeError.d.ts +2 -2
  43. package/dist/routes/rest/routeError.d.ts.map +1 -1
  44. package/dist/routes/rest/routeError.js.map +1 -1
  45. package/dist/routes/rest/types.d.ts +7 -7
  46. package/dist/routes/rest/types.d.ts.map +1 -1
  47. package/dist/routes/rest/types.js.map +1 -1
  48. package/dist/scss/app.scss +208 -0
  49. package/dist/scss/colors.scss +269 -0
  50. package/dist/scss/custom.css +1 -0
  51. package/dist/scss/queries.scss +27 -0
  52. package/dist/scss/resets.scss +17 -0
  53. package/dist/scss/styles.scss +11 -0
  54. package/dist/scss/svg.scss +10 -0
  55. package/dist/scss/toasts.scss +111 -0
  56. package/dist/scss/type.scss +117 -0
  57. package/dist/scss/vars.scss +213 -0
  58. package/dist/scss/z-index.scss +9 -0
  59. package/dist/templates/Default/Wrapper/index.scss +25 -0
  60. package/dist/templates/Default/index.scss +67 -0
  61. package/dist/templates/Minimal/index.scss +28 -0
  62. package/dist/utilities/addDataAndFileToRequest.d.ts +3 -6
  63. package/dist/utilities/addDataAndFileToRequest.d.ts.map +1 -1
  64. package/dist/utilities/addDataAndFileToRequest.js +15 -18
  65. package/dist/utilities/addDataAndFileToRequest.js.map +1 -1
  66. package/dist/utilities/addLocalesToRequest.d.ts +2 -5
  67. package/dist/utilities/addLocalesToRequest.d.ts.map +1 -1
  68. package/dist/utilities/addLocalesToRequest.js +8 -9
  69. package/dist/utilities/addLocalesToRequest.js.map +1 -1
  70. package/dist/utilities/createPayloadRequest.d.ts.map +1 -1
  71. package/dist/utilities/createPayloadRequest.js +3 -1
  72. package/dist/utilities/createPayloadRequest.js.map +1 -1
  73. package/dist/utilities/headersWithCors.d.ts +2 -2
  74. package/dist/utilities/headersWithCors.d.ts.map +1 -1
  75. package/dist/utilities/headersWithCors.js.map +1 -1
  76. package/dist/utilities/initPage/index.d.ts.map +1 -1
  77. package/dist/utilities/initPage/index.js.map +1 -1
  78. package/dist/utilities/mergeHeaders.d.ts +2 -0
  79. package/dist/utilities/mergeHeaders.d.ts.map +1 -0
  80. package/dist/utilities/mergeHeaders.js +37 -0
  81. package/dist/utilities/mergeHeaders.js.map +1 -0
  82. package/dist/views/API/RenderJSON/index.scss +90 -0
  83. package/dist/views/API/index.scss +124 -0
  84. package/dist/views/Account/Settings/index.scss +46 -0
  85. package/dist/views/CreateFirstUser/index.scss +5 -0
  86. package/dist/views/Dashboard/Default/index.scss +58 -0
  87. package/dist/views/Document/getDocumentData.d.ts +2 -2
  88. package/dist/views/Document/getDocumentData.d.ts.map +1 -1
  89. package/dist/views/Document/getDocumentData.js.map +1 -1
  90. package/dist/views/Edit/Default/Auth/APIKey.js.map +1 -1
  91. package/dist/views/Edit/Default/Auth/index.d.ts.map +1 -1
  92. package/dist/views/Edit/Default/Auth/index.js +10 -3
  93. package/dist/views/Edit/Default/Auth/index.js.map +1 -1
  94. package/dist/views/Edit/Default/Auth/index.scss +61 -0
  95. package/dist/views/Edit/Default/Auth/types.d.ts +1 -0
  96. package/dist/views/Edit/Default/Auth/types.d.ts.map +1 -1
  97. package/dist/views/Edit/Default/Auth/types.js.map +1 -1
  98. package/dist/views/Edit/Default/index.d.ts.map +1 -1
  99. package/dist/views/Edit/Default/index.js +1 -0
  100. package/dist/views/Edit/Default/index.js.map +1 -1
  101. package/dist/views/Edit/Default/index.scss +21 -0
  102. package/dist/views/ForgotPassword/ForgotPasswordForm/index.d.ts.map +1 -1
  103. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +34 -6
  104. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  105. package/dist/views/List/Default/index.scss +195 -0
  106. package/dist/views/LivePreview/IFrame/index.scss +7 -0
  107. package/dist/views/LivePreview/Preview/index.scss +41 -0
  108. package/dist/views/LivePreview/Toolbar/Controls/index.scss +59 -0
  109. package/dist/views/LivePreview/Toolbar/SizeInput/index.scss +10 -0
  110. package/dist/views/LivePreview/Toolbar/index.scss +41 -0
  111. package/dist/views/LivePreview/ToolbarArea/index.scss +4 -0
  112. package/dist/views/LivePreview/index.scss +66 -0
  113. package/dist/views/Login/LoginForm/index.d.ts.map +1 -1
  114. package/dist/views/Login/LoginForm/index.js +38 -8
  115. package/dist/views/Login/LoginForm/index.js.map +1 -1
  116. package/dist/views/Login/LoginForm/index.scss +8 -0
  117. package/dist/views/Login/index.scss +8 -0
  118. package/dist/views/Logout/index.scss +20 -0
  119. package/dist/views/NotFound/index.scss +37 -0
  120. package/dist/views/ResetPassword/index.scss +5 -0
  121. package/dist/views/Unauthorized/index.scss +36 -0
  122. package/dist/views/Verify/index.scss +14 -0
  123. package/dist/views/Version/Default/index.scss +70 -0
  124. package/dist/views/Version/RenderFieldsToDiff/Label/index.scss +4 -0
  125. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +34 -0
  126. package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.scss +12 -0
  127. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.scss +13 -0
  128. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.scss +13 -0
  129. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.scss +13 -0
  130. package/dist/views/Version/RenderFieldsToDiff/index.scss +18 -0
  131. package/dist/views/Version/Restore/index.scss +30 -0
  132. package/dist/views/Version/SelectComparison/index.scss +13 -0
  133. package/dist/views/Version/SelectLocales/index.scss +7 -0
  134. package/dist/views/Versions/index.scss +108 -0
  135. package/package.json +6 -6
@@ -0,0 +1,41 @@
1
+ @import '../../../scss/styles.scss';
2
+
3
+ .live-preview-window {
4
+ background-color: var(--theme-bg);
5
+ width: 60%;
6
+ flex-shrink: 0;
7
+ flex-grow: 0;
8
+ position: sticky;
9
+ top: var(--doc-controls-height);
10
+ height: calc(100vh - var(--doc-controls-height));
11
+ overflow: hidden;
12
+
13
+ &__wrapper {
14
+ display: flex;
15
+ flex-direction: column;
16
+ height: 100%;
17
+ justify-content: flex-start;
18
+ }
19
+
20
+ &__main {
21
+ flex-grow: 1;
22
+ height: 100%;
23
+ width: 100%;
24
+ }
25
+
26
+ &--has-breakpoint {
27
+ .live-preview-iframe {
28
+ border: 1px solid var(--theme-elevation-100);
29
+ }
30
+
31
+ .live-preview-window {
32
+ &__main {
33
+ padding: var(--base);
34
+ }
35
+ }
36
+ }
37
+
38
+ @include mid-break {
39
+ width: 100%;
40
+ }
41
+ }
@@ -0,0 +1,59 @@
1
+ @import '../../../../scss/styles.scss';
2
+
3
+ .live-preview-toolbar-controls {
4
+ display: flex;
5
+ align-items: center;
6
+ gap: calc(var(--base) / 3);
7
+
8
+ &__breakpoint {
9
+ border: none;
10
+ background: transparent;
11
+ height: var(--base);
12
+
13
+ &:focus {
14
+ outline: none;
15
+ }
16
+ }
17
+
18
+ &__device-size {
19
+ display: flex;
20
+ align-items: center;
21
+ }
22
+
23
+ &__size {
24
+ width: 50px;
25
+ height: var(--base);
26
+ display: flex;
27
+ align-items: center;
28
+ border: 1px solid var(--theme-elevation-200);
29
+ background: var(--theme-elevation-100);
30
+ border-radius: 2px;
31
+ font-size: small;
32
+ }
33
+
34
+ &__zoom {
35
+ width: 55px;
36
+ border: none;
37
+ background: transparent;
38
+ height: var(--base);
39
+
40
+ &:focus {
41
+ outline: none;
42
+ }
43
+ }
44
+
45
+ &__external {
46
+ flex-shrink: 0;
47
+ display: flex;
48
+ width: var(--base);
49
+ height: var(--base);
50
+ align-items: center;
51
+ justify-content: center;
52
+ padding: 6px 0;
53
+ }
54
+
55
+ .popup-button {
56
+ display: flex;
57
+ align-items: center;
58
+ }
59
+ }
@@ -0,0 +1,10 @@
1
+ .toolbar-input {
2
+ width: 50px;
3
+ height: var(--base);
4
+ display: flex;
5
+ align-items: center;
6
+ border: 1px solid var(--theme-elevation-200);
7
+ background: var(--theme-elevation-100);
8
+ border-radius: 2px;
9
+ font-size: small;
10
+ }
@@ -0,0 +1,41 @@
1
+ @import '../../../scss/styles.scss';
2
+
3
+ .live-preview-toolbar {
4
+ display: flex;
5
+ background-color: var(--theme-bg);
6
+ color: var(--theme-text);
7
+ height: calc(var(--base) * 1.75);
8
+ align-items: center;
9
+ flex-shrink: 0;
10
+
11
+ &--static {
12
+ position: relative;
13
+ width: 100%;
14
+ justify-content: center;
15
+ border-bottom: 1px solid var(--theme-elevation-100);
16
+ }
17
+
18
+ &--draggable {
19
+ @include shadow-lg;
20
+ position: absolute;
21
+ top: 0;
22
+ left: 0;
23
+ margin: 0;
24
+ border-radius: 4px;
25
+ }
26
+
27
+ &__drag-handle {
28
+ background: transparent;
29
+ border: 0;
30
+ padding: 0;
31
+ cursor: grab;
32
+
33
+ .icon--drag-handle .fill {
34
+ fill: var(--theme-elevation-300);
35
+ }
36
+
37
+ &:active {
38
+ cursor: grabbing;
39
+ }
40
+ }
41
+ }
@@ -0,0 +1,4 @@
1
+ .toolbar-area {
2
+ width: 100%;
3
+ height: 100%;
4
+ }
@@ -0,0 +1,66 @@
1
+ @import '../../scss/styles.scss';
2
+
3
+ .live-preview {
4
+ width: 100%;
5
+ display: flex;
6
+ --gradient: linear-gradient(to left, rgba(0, 0, 0, 0.04) 0%, transparent 100%);
7
+
8
+ [dir='rtl'] & {
9
+ flex-direction: row-reverse;
10
+ }
11
+
12
+ &--popup-open {
13
+ .live-preview {
14
+ &__edit {
15
+ padding-right: var(--gutter-h);
16
+ }
17
+ }
18
+ }
19
+
20
+ &__main {
21
+ width: 40%;
22
+ display: flex;
23
+ flex-direction: column;
24
+ min-height: 100%;
25
+ position: relative;
26
+
27
+ &--popup-open {
28
+ width: 100%;
29
+ }
30
+
31
+ &::after {
32
+ content: ' ';
33
+ position: absolute;
34
+ top: 0;
35
+ right: 0;
36
+ width: calc(var(--base) * 2);
37
+ height: 100%;
38
+ background: var(--gradient);
39
+ pointer-events: none;
40
+ z-index: -1;
41
+ }
42
+ }
43
+
44
+ @include mid-break {
45
+ flex-direction: column;
46
+
47
+ &__main {
48
+ min-height: initial;
49
+ width: 100%;
50
+
51
+ &::after {
52
+ display: none;
53
+ }
54
+ }
55
+
56
+ &__form {
57
+ display: block;
58
+ }
59
+ }
60
+ }
61
+
62
+ html[data-theme='dark'] {
63
+ .live-preview {
64
+ --gradient: linear-gradient(to left, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0) 100%);
65
+ }
66
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Login/LoginForm/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAA;AAiBzB,OAAO,cAAc,CAAA;AAErB,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC;IAC/B,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;CAC/D,CAoFA,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Login/LoginForm/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAA;AAkBzB,OAAO,cAAc,CAAA;AAErB,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC;IAC/B,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;CAC/D,CAwHA,CAAA"}
@@ -4,25 +4,35 @@ import LinkImport from 'next/link.js';
4
4
  import React from 'react';
5
5
  const baseClass = 'login__form';
6
6
  const Link = LinkImport.default || LinkImport;
7
- import { EmailField, Form, FormSubmit, PasswordField, useConfig, useTranslation } from '@payloadcms/ui';
8
- import { email, password } from 'payload/shared';
7
+ import { EmailField, Form, FormSubmit, PasswordField, TextField, useConfig, useTranslation } from '@payloadcms/ui';
8
+ import { email, password, text } from 'payload/shared';
9
9
  export const LoginForm = ({ searchParams })=>{
10
10
  const config = useConfig();
11
11
  const { admin: { autoLogin, routes: { forgot: forgotRoute }, user: userSlug }, routes: { admin, api } } = config;
12
+ const collectionConfig = config.collections?.find((collection)=>collection?.slug === userSlug);
13
+ const loginWithUsername = collectionConfig?.auth?.loginWithUsername;
12
14
  const { t } = useTranslation();
13
15
  const prefillForm = autoLogin && autoLogin.prefillOnly;
14
16
  const initialState = {
15
- email: {
16
- initialValue: prefillForm ? autoLogin.email : undefined,
17
- valid: true,
18
- value: prefillForm ? autoLogin.email : undefined
19
- },
20
17
  password: {
21
18
  initialValue: prefillForm ? autoLogin.password : undefined,
22
19
  valid: true,
23
20
  value: prefillForm ? autoLogin.password : undefined
24
21
  }
25
22
  };
23
+ if (loginWithUsername) {
24
+ initialState.username = {
25
+ initialValue: prefillForm ? autoLogin.username : undefined,
26
+ valid: true,
27
+ value: prefillForm ? autoLogin.username : undefined
28
+ };
29
+ } else {
30
+ initialState.email = {
31
+ initialValue: prefillForm ? autoLogin.email : undefined,
32
+ valid: true,
33
+ value: prefillForm ? autoLogin.email : undefined
34
+ };
35
+ }
26
36
  return /*#__PURE__*/ _jsxs(Form, {
27
37
  action: `${api}/${userSlug}/login`,
28
38
  className: baseClass,
@@ -35,7 +45,27 @@ export const LoginForm = ({ searchParams })=>{
35
45
  /*#__PURE__*/ _jsxs("div", {
36
46
  className: `${baseClass}__inputWrap`,
37
47
  children: [
38
- /*#__PURE__*/ _jsx(EmailField, {
48
+ loginWithUsername ? /*#__PURE__*/ _jsx(TextField, {
49
+ label: t('authentication:username'),
50
+ name: "username",
51
+ required: true,
52
+ validate: (value)=>text(value, {
53
+ name: 'username',
54
+ type: 'text',
55
+ data: {},
56
+ preferences: {
57
+ fields: {}
58
+ },
59
+ req: {
60
+ payload: {
61
+ config
62
+ },
63
+ t
64
+ },
65
+ required: true,
66
+ siblingData: {}
67
+ })
68
+ }) : /*#__PURE__*/ _jsx(EmailField, {
39
69
  autoComplete: "email",
40
70
  label: t('general:email'),
41
71
  name: "email",
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/views/Login/LoginForm/index.tsx"],"sourcesContent":["'use client'\n\nimport LinkImport from 'next/link.js'\nimport React from 'react'\n\nconst baseClass = 'login__form'\nconst Link = (LinkImport.default || LinkImport) as unknown as typeof LinkImport.default\n\nimport type { FormState, PayloadRequestWithData } from 'payload'\n\nimport {\n EmailField,\n Form,\n FormSubmit,\n PasswordField,\n useConfig,\n useTranslation,\n} from '@payloadcms/ui'\nimport { email, password } from 'payload/shared'\n\nimport './index.scss'\n\nexport const LoginForm: React.FC<{\n searchParams: { [key: string]: string | string[] | undefined }\n}> = ({ searchParams }) => {\n const config = useConfig()\n\n const {\n admin: {\n autoLogin,\n routes: { forgot: forgotRoute },\n user: userSlug,\n },\n routes: { admin, api },\n } = config\n\n const { t } = useTranslation()\n\n const prefillForm = autoLogin && autoLogin.prefillOnly\n\n const initialState: FormState = {\n email: {\n initialValue: prefillForm ? autoLogin.email : undefined,\n valid: true,\n value: prefillForm ? autoLogin.email : undefined,\n },\n password: {\n initialValue: prefillForm ? autoLogin.password : undefined,\n valid: true,\n value: prefillForm ? autoLogin.password : undefined,\n },\n }\n\n return (\n <Form\n action={`${api}/${userSlug}/login`}\n className={baseClass}\n disableSuccessStatus\n initialState={initialState}\n method=\"POST\"\n redirect={typeof searchParams?.redirect === 'string' ? searchParams.redirect : admin}\n waitForAutocomplete\n >\n <div className={`${baseClass}__inputWrap`}>\n <EmailField\n autoComplete=\"email\"\n label={t('general:email')}\n name=\"email\"\n required\n validate={(value) =>\n email(value, {\n name: 'email',\n type: 'email',\n data: {},\n preferences: { fields: {} },\n req: { t } as PayloadRequestWithData,\n required: true,\n siblingData: {},\n })\n }\n />\n <PasswordField\n autoComplete=\"off\"\n label={t('general:password')}\n name=\"password\"\n required\n validate={(value) =>\n password(value, {\n name: 'password',\n type: 'text',\n data: {},\n preferences: { fields: {} },\n req: {\n payload: {\n config,\n },\n t,\n } as PayloadRequestWithData,\n required: true,\n siblingData: {},\n })\n }\n />\n </div>\n <Link href={`${admin}${forgotRoute}`}>{t('authentication:forgotPasswordQuestion')}</Link>\n <FormSubmit>{t('authentication:login')}</FormSubmit>\n </Form>\n )\n}\n"],"names":["LinkImport","React","baseClass","Link","default","EmailField","Form","FormSubmit","PasswordField","useConfig","useTranslation","email","password","LoginForm","searchParams","config","admin","autoLogin","routes","forgot","forgotRoute","user","userSlug","api","t","prefillForm","prefillOnly","initialState","initialValue","undefined","valid","value","action","className","disableSuccessStatus","method","redirect","waitForAutocomplete","div","autoComplete","label","name","required","validate","type","data","preferences","fields","req","siblingData","payload","href"],"mappings":"AAAA;;AAEA,OAAOA,gBAAgB,eAAc;AACrC,OAAOC,WAAW,QAAO;AAEzB,MAAMC,YAAY;AAClB,MAAMC,OAAQH,WAAWI,OAAO,IAAIJ;AAIpC,SACEK,UAAU,EACVC,IAAI,EACJC,UAAU,EACVC,aAAa,EACbC,SAAS,EACTC,cAAc,QACT,iBAAgB;AACvB,SAASC,KAAK,EAAEC,QAAQ,QAAQ,iBAAgB;AAIhD,OAAO,MAAMC,YAER,CAAC,EAAEC,YAAY,EAAE;IACpB,MAAMC,SAASN;IAEf,MAAM,EACJO,OAAO,EACLC,SAAS,EACTC,QAAQ,EAAEC,QAAQC,WAAW,EAAE,EAC/BC,MAAMC,QAAQ,EACf,EACDJ,QAAQ,EAAEF,KAAK,EAAEO,GAAG,EAAE,EACvB,GAAGR;IAEJ,MAAM,EAAES,CAAC,EAAE,GAAGd;IAEd,MAAMe,cAAcR,aAAaA,UAAUS,WAAW;IAEtD,MAAMC,eAA0B;QAC9BhB,OAAO;YACLiB,cAAcH,cAAcR,UAAUN,KAAK,GAAGkB;YAC9CC,OAAO;YACPC,OAAON,cAAcR,UAAUN,KAAK,GAAGkB;QACzC;QACAjB,UAAU;YACRgB,cAAcH,cAAcR,UAAUL,QAAQ,GAAGiB;YACjDC,OAAO;YACPC,OAAON,cAAcR,UAAUL,QAAQ,GAAGiB;QAC5C;IACF;IAEA,qBACE,MAACvB;QACC0B,QAAQ,CAAC,EAAET,IAAI,CAAC,EAAED,SAAS,MAAM,CAAC;QAClCW,WAAW/B;QACXgC,oBAAoB;QACpBP,cAAcA;QACdQ,QAAO;QACPC,UAAU,OAAOtB,cAAcsB,aAAa,WAAWtB,aAAasB,QAAQ,GAAGpB;QAC/EqB,mBAAmB;;0BAEnB,MAACC;gBAAIL,WAAW,CAAC,EAAE/B,UAAU,WAAW,CAAC;;kCACvC,KAACG;wBACCkC,cAAa;wBACbC,OAAOhB,EAAE;wBACTiB,MAAK;wBACLC,QAAQ;wBACRC,UAAU,CAACZ,QACTpB,MAAMoB,OAAO;gCACXU,MAAM;gCACNG,MAAM;gCACNC,MAAM,CAAC;gCACPC,aAAa;oCAAEC,QAAQ,CAAC;gCAAE;gCAC1BC,KAAK;oCAAExB;gCAAE;gCACTkB,UAAU;gCACVO,aAAa,CAAC;4BAChB;;kCAGJ,KAACzC;wBACC+B,cAAa;wBACbC,OAAOhB,EAAE;wBACTiB,MAAK;wBACLC,QAAQ;wBACRC,UAAU,CAACZ,QACTnB,SAASmB,OAAO;gCACdU,MAAM;gCACNG,MAAM;gCACNC,MAAM,CAAC;gCACPC,aAAa;oCAAEC,QAAQ,CAAC;gCAAE;gCAC1BC,KAAK;oCACHE,SAAS;wCACPnC;oCACF;oCACAS;gCACF;gCACAkB,UAAU;gCACVO,aAAa,CAAC;4BAChB;;;;0BAIN,KAAC9C;gBAAKgD,MAAM,CAAC,EAAEnC,MAAM,EAAEI,YAAY,CAAC;0BAAGI,EAAE;;0BACzC,KAACjB;0BAAYiB,EAAE;;;;AAGrB,EAAC"}
1
+ {"version":3,"sources":["../../../../src/views/Login/LoginForm/index.tsx"],"sourcesContent":["'use client'\n\nimport LinkImport from 'next/link.js'\nimport React from 'react'\n\nconst baseClass = 'login__form'\nconst Link = (LinkImport.default || LinkImport) as unknown as typeof LinkImport.default\n\nimport type { FormState, PayloadRequest } from 'payload'\n\nimport {\n EmailField,\n Form,\n FormSubmit,\n PasswordField,\n TextField,\n useConfig,\n useTranslation,\n} from '@payloadcms/ui'\nimport { email, password, text } from 'payload/shared'\n\nimport './index.scss'\n\nexport const LoginForm: React.FC<{\n searchParams: { [key: string]: string | string[] | undefined }\n}> = ({ searchParams }) => {\n const config = useConfig()\n\n const {\n admin: {\n autoLogin,\n routes: { forgot: forgotRoute },\n user: userSlug,\n },\n routes: { admin, api },\n } = config\n\n const collectionConfig = config.collections?.find((collection) => collection?.slug === userSlug)\n const loginWithUsername = collectionConfig?.auth?.loginWithUsername\n\n const { t } = useTranslation()\n\n const prefillForm = autoLogin && autoLogin.prefillOnly\n\n const initialState: FormState = {\n password: {\n initialValue: prefillForm ? autoLogin.password : undefined,\n valid: true,\n value: prefillForm ? autoLogin.password : undefined,\n },\n }\n\n if (loginWithUsername) {\n initialState.username = {\n initialValue: prefillForm ? autoLogin.username : undefined,\n valid: true,\n value: prefillForm ? autoLogin.username : undefined,\n }\n } else {\n initialState.email = {\n initialValue: prefillForm ? autoLogin.email : undefined,\n valid: true,\n value: prefillForm ? autoLogin.email : undefined,\n }\n }\n\n return (\n <Form\n action={`${api}/${userSlug}/login`}\n className={baseClass}\n disableSuccessStatus\n initialState={initialState}\n method=\"POST\"\n redirect={typeof searchParams?.redirect === 'string' ? searchParams.redirect : admin}\n waitForAutocomplete\n >\n <div className={`${baseClass}__inputWrap`}>\n {loginWithUsername ? (\n <TextField\n label={t('authentication:username')}\n name=\"username\"\n required\n validate={(value) =>\n text(value, {\n name: 'username',\n type: 'text',\n data: {},\n preferences: { fields: {} },\n req: {\n payload: {\n config,\n },\n t,\n } as PayloadRequest,\n required: true,\n siblingData: {},\n })\n }\n />\n ) : (\n <EmailField\n autoComplete=\"email\"\n label={t('general:email')}\n name=\"email\"\n required\n validate={(value) =>\n email(value, {\n name: 'email',\n type: 'email',\n data: {},\n preferences: { fields: {} },\n req: { t } as PayloadRequest,\n required: true,\n siblingData: {},\n })\n }\n />\n )}\n <PasswordField\n autoComplete=\"off\"\n label={t('general:password')}\n name=\"password\"\n required\n validate={(value) =>\n password(value, {\n name: 'password',\n type: 'text',\n data: {},\n preferences: { fields: {} },\n req: {\n payload: {\n config,\n },\n t,\n } as PayloadRequest,\n required: true,\n siblingData: {},\n })\n }\n />\n </div>\n <Link href={`${admin}${forgotRoute}`}>{t('authentication:forgotPasswordQuestion')}</Link>\n <FormSubmit>{t('authentication:login')}</FormSubmit>\n </Form>\n )\n}\n"],"names":["LinkImport","React","baseClass","Link","default","EmailField","Form","FormSubmit","PasswordField","TextField","useConfig","useTranslation","email","password","text","LoginForm","searchParams","config","admin","autoLogin","routes","forgot","forgotRoute","user","userSlug","api","collectionConfig","collections","find","collection","slug","loginWithUsername","auth","t","prefillForm","prefillOnly","initialState","initialValue","undefined","valid","value","username","action","className","disableSuccessStatus","method","redirect","waitForAutocomplete","div","label","name","required","validate","type","data","preferences","fields","req","payload","siblingData","autoComplete","href"],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ .login__form {
2
+ &__inputWrap {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: var(--base);
6
+ margin-bottom: calc(var(--base) / 4);
7
+ }
8
+ }
@@ -0,0 +1,8 @@
1
+ .login {
2
+ &__brand {
3
+ display: flex;
4
+ justify-content: center;
5
+ width: 100%;
6
+ margin-bottom: calc(var(--base) * 2);
7
+ }
8
+ }
@@ -0,0 +1,20 @@
1
+ .logout {
2
+ display: flex;
3
+ align-items: center;
4
+ flex-wrap: wrap;
5
+ min-height: 100vh;
6
+
7
+ &__wrap {
8
+ & > *:first-child {
9
+ margin-top: 0;
10
+ }
11
+
12
+ & > *:last-child {
13
+ margin-bottom: 0;
14
+ }
15
+
16
+ .btn {
17
+ margin: 0;
18
+ }
19
+ }
20
+ }
@@ -0,0 +1,37 @@
1
+ @import '../../scss/styles.scss';
2
+
3
+ .not-found {
4
+ margin-top: var(--base);
5
+ display: flex;
6
+
7
+ & > * {
8
+ &:first-child {
9
+ margin-top: 0;
10
+ }
11
+ &:last-child {
12
+ margin-bottom: 0;
13
+ }
14
+ }
15
+
16
+ &__button {
17
+ margin: 0;
18
+ }
19
+
20
+ &--margin-top-large {
21
+ margin-top: calc(var(--base) * 2);
22
+ }
23
+
24
+ @include large-break {
25
+ &--margin-top-large {
26
+ margin-top: var(--base);
27
+ }
28
+ }
29
+
30
+ @include small-break {
31
+ margin-top: calc(var(--base) / 2);
32
+
33
+ &--margin-top-large {
34
+ margin-top: calc(var(--base) / 2);
35
+ }
36
+ }
37
+ }
@@ -0,0 +1,5 @@
1
+ .reset-password {
2
+ form > .field-type {
3
+ margin-bottom: var(--base);
4
+ }
5
+ }
@@ -0,0 +1,36 @@
1
+ @import '../../scss/styles.scss';
2
+
3
+ .unauthorized {
4
+ margin-top: var(--base);
5
+
6
+ & > * {
7
+ &:first-child {
8
+ margin-top: 0;
9
+ }
10
+ &:last-child {
11
+ margin-bottom: 0;
12
+ }
13
+ }
14
+
15
+ &__button {
16
+ margin: 0;
17
+ }
18
+
19
+ &--margin-top-large {
20
+ margin-top: calc(var(--base) * 2);
21
+ }
22
+
23
+ @include large-break {
24
+ &--margin-top-large {
25
+ margin-top: var(--base);
26
+ }
27
+ }
28
+
29
+ @include small-break {
30
+ margin-top: calc(var(--base) / 2);
31
+
32
+ &--margin-top-large {
33
+ margin-top: calc(var(--base) / 2);
34
+ }
35
+ }
36
+ }
@@ -0,0 +1,14 @@
1
+ .verify {
2
+ display: flex;
3
+ align-items: center;
4
+ text-align: center;
5
+ flex-wrap: wrap;
6
+ min-height: 100vh;
7
+
8
+ &__brand {
9
+ display: flex;
10
+ justify-content: center;
11
+ width: 100%;
12
+ margin-bottom: calc(var(--base) * 2);
13
+ }
14
+ }
@@ -0,0 +1,70 @@
1
+ @import '../../../scss/styles.scss';
2
+
3
+ .view-version {
4
+ width: 100%;
5
+ padding-bottom: var(--spacing-view-bottom);
6
+
7
+ &__wrap {
8
+ padding-top: calc(var(--base) * 1.5);
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: var(--base);
12
+ }
13
+
14
+ &__header-wrap {
15
+ display: flex;
16
+ flex-direction: column;
17
+ gap: calc(var(--base) / 4);
18
+ }
19
+
20
+ &__header {
21
+ display: flex;
22
+ align-items: center;
23
+ flex-wrap: wrap;
24
+
25
+ h2 {
26
+ margin: 0;
27
+ }
28
+ }
29
+
30
+ &__created-at {
31
+ margin: 0;
32
+ color: var(--theme-elevation-500);
33
+ }
34
+
35
+ &__controls {
36
+ display: flex;
37
+ gap: var(--base);
38
+
39
+ > * {
40
+ flex-basis: 100%;
41
+ }
42
+ }
43
+
44
+ &__restore {
45
+ margin: 0 0 0 var(--base);
46
+ }
47
+
48
+ @include mid-break {
49
+ &__intro,
50
+ &__header {
51
+ display: block;
52
+ }
53
+
54
+ &__controls {
55
+ flex-direction: column;
56
+ gap: calc(var(--base) / 4);
57
+ }
58
+
59
+ &__restore {
60
+ margin: calc(var(--base) * 0.5) 0 0 0;
61
+ }
62
+ }
63
+
64
+ @include small-break {
65
+ &__wrap {
66
+ padding-top: calc(var(--base) / 2);
67
+ gap: calc(var(--base) / 2);
68
+ }
69
+ }
70
+ }
@@ -0,0 +1,4 @@
1
+ .field-diff-label {
2
+ margin-bottom: calc(var(--base) * 0.25);
3
+ font-weight: 600;
4
+ }
@@ -0,0 +1,34 @@
1
+ .iterable-diff {
2
+ margin-bottom: calc(var(--base) * 2);
3
+
4
+ &__locale-label {
5
+ background: var(--theme-elevation-100);
6
+ padding: calc(var(--base) * 0.25);
7
+ // border-radius: $style-radius-m;
8
+ [dir='ltr'] & {
9
+ margin-right: calc(var(--base) * 0.25);
10
+ }
11
+ [dir='rtl'] & {
12
+ margin-left: calc(var(--base) * 0.25);
13
+ }
14
+ }
15
+
16
+ &__wrap {
17
+ margin: calc(var(--base) * 0.5);
18
+ [dir='ltr'] & {
19
+ padding-left: calc(var(--base) * 0.5);
20
+ // border-left: $style-stroke-width-s solid var(--theme-elevation-150);
21
+ }
22
+ [dir='rtl'] & {
23
+ padding-right: calc(var(--base) * 0.5);
24
+ // border-right: $style-stroke-width-s solid var(--theme-elevation-150);
25
+ }
26
+ }
27
+
28
+ &__no-rows {
29
+ font-family: monospace;
30
+ background-color: var(--theme-elevation-50);
31
+ // padding: base(0.125) calc(var(--base) * 0.5);
32
+ // margin: base(0.125) 0;
33
+ }
34
+ }
@@ -0,0 +1,12 @@
1
+ .nested-diff {
2
+ &__wrap--gutter {
3
+ [dir='ltr'] & {
4
+ padding-left: calc(var(--base) * 0.25);
5
+ // border-left: $style-stroke-width-s solid var(--theme-elevation-150);
6
+ }
7
+ [dir='rtl'] & {
8
+ padding-right: calc(var(--base) * 0.25);
9
+ // border-right: $style-stroke-width-s solid var(--theme-elevation-150);
10
+ }
11
+ }
12
+ }
@@ -0,0 +1,13 @@
1
+ .relationship-diff {
2
+ &__locale-label {
3
+ [dir='ltr'] & {
4
+ margin-right: calc(var(--base) * 0.25);
5
+ }
6
+ [dir='rtl'] & {
7
+ margin-left: calc(var(--base) * 0.25);
8
+ }
9
+ background: var(--theme-elevation-100);
10
+ padding: calc(var(--base) * 0.25);
11
+ // border-radius: $style-radius-m;
12
+ }
13
+ }
@@ -0,0 +1,13 @@
1
+ .select-diff {
2
+ &__locale-label {
3
+ [dir='ltr'] & {
4
+ margin-right: calc(var(--base) * 0.25);
5
+ }
6
+ [dir='rtl'] & {
7
+ margin-left: calc(var(--base) * 0.25);
8
+ }
9
+ background: var(--theme-elevation-100);
10
+ padding: calc(var(--base) * 0.25);
11
+ // border-radius: $style-radius-m;
12
+ }
13
+ }
@@ -0,0 +1,13 @@
1
+ .text-diff {
2
+ &__locale-label {
3
+ [dir='ltr'] & {
4
+ margin-right: calc(var(--base) * 0.25);
5
+ }
6
+ [dir='rtl'] & {
7
+ margin-left: calc(var(--base) * 0.25);
8
+ }
9
+ background: var(--theme-elevation-100);
10
+ padding: calc(var(--base) * 0.25);
11
+ // border-radius: $style-radius-m;
12
+ }
13
+ }
@@ -0,0 +1,18 @@
1
+ @import '../../../scss/styles.scss';
2
+
3
+ .render-field-diffs {
4
+ display: flex;
5
+ flex-direction: column;
6
+ gap: var(--base);
7
+
8
+ &__field {
9
+ overflow-wrap: anywhere;
10
+ display: flex;
11
+ flex-direction: column;
12
+ gap: var(--base);
13
+ }
14
+
15
+ @include small-break {
16
+ gap: calc(var(--base) / 2);
17
+ }
18
+ }