@qwickapps/cms 0.4.1 → 0.5.0

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.
package/README.md CHANGED
@@ -2,11 +2,11 @@
2
2
 
3
3
  > Reusable Payload CMS collections, globals, and components for building QwickApps-powered websites
4
4
 
5
- ## What's New in v0.4.0
5
+ ## What's New in v0.5.0
6
6
 
7
- - **E-Commerce Integration**: Enhanced BlockRenderer with ProductCard component support for building e-commerce content
8
- - **Cart Functionality**: New client-side exports enable shopping cart integration in content blocks
9
- - **Product Support**: Pages and Posts collections now support e-commerce product displays
7
+ - **HeroSlideshows Collection**: New collection for managing hero slideshow content in the page builder
8
+ - **PeerDependencies Change**: `@payloadcms/email-nodemailer` and `@payloadcms/live-preview-react` are now peerDependencies. Add them to your project's `package.json` directly.
9
+ - **Bug Fixes**: Fixed infinite loop, missing React keys, and hero button contrast issues
10
10
 
11
11
  See [CHANGELOG.md](./CHANGELOG.md) for full details.
12
12
 
@@ -4,7 +4,6 @@ export { Footer } from './Footer.js';
4
4
  export { FormSubmissions } from './FormSubmissions.js';
5
5
  export { Forms } from './Forms.js';
6
6
  export { HeroBlocks } from './HeroBlocks.js';
7
- export { HeroSlideshows } from './HeroSlideshows.js';
8
7
  export { Media } from './Media.js';
9
8
  export { Navigation } from './Navigation.js';
10
9
  export { Pages } from './Pages.js';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/collections/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAGlC,cAAc,kBAAkB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/collections/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAGlC,cAAc,kBAAkB,CAAA"}
@@ -5,7 +5,6 @@ export { Footer } from './Footer.js';
5
5
  export { FormSubmissions } from './FormSubmissions.js';
6
6
  export { Forms } from './Forms.js';
7
7
  export { HeroBlocks } from './HeroBlocks.js';
8
- export { HeroSlideshows } from './HeroSlideshows.js';
9
8
  export { Media } from './Media.js';
10
9
  export { Navigation } from './Navigation.js';
11
10
  export { Pages } from './Pages.js';
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/collections/index.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAElC,iDAAiD;AACjD,cAAc,kBAAkB,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/collections/index.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAElC,iDAAiD;AACjD,cAAc,kBAAkB,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@qwickapps/cms",
3
- "version": "0.4.1",
3
+ "version": "0.5.0",
4
4
  "description": "QwickApps CMS - Reusable Payload CMS collections, globals, and components",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -53,10 +53,20 @@
53
53
  "./styles/admin-theme.css": "./dist/styles/admin-theme.css",
54
54
  "./styles/admin-theme.scss": "./src/styles/admin-theme.scss"
55
55
  },
56
+ "scripts": {
57
+ "build": "tsc && npm run copy-styles",
58
+ "copy-styles": "mkdir -p dist/styles dist/admin/components/styles && cp src/styles/*.css dist/styles/ 2>/dev/null || true && cp src/admin/components/styles/*.css dist/admin/components/styles/ 2>/dev/null || true",
59
+ "dev": "tsc --watch",
60
+ "clean": "rm -rf dist",
61
+ "validate": "./qa/clean-install/validate.sh",
62
+ "validate:safe": "test -f ./qa/clean-install/validate.sh && npm run validate || echo 'Validation skipped - qa scripts not available'"
63
+ },
56
64
  "peerDependencies": {
57
65
  "@mui/icons-material": ">=6.0.0",
58
66
  "@mui/material": ">=6.0.0",
59
67
  "@payloadcms/db-postgres": "^3.0.0",
68
+ "@payloadcms/email-nodemailer": "^3.0.0",
69
+ "@payloadcms/live-preview-react": "^3.0.0",
60
70
  "@payloadcms/next": "^3.0.0",
61
71
  "@payloadcms/richtext-lexical": "^3.0.0",
62
72
  "@payloadcms/ui": "^3.0.0",
@@ -71,6 +81,8 @@
71
81
  "@mui/icons-material": "^6.0.0",
72
82
  "@mui/material": "^6.0.0",
73
83
  "@payloadcms/db-postgres": "^3.0.0",
84
+ "@payloadcms/email-nodemailer": "^3.0.0",
85
+ "@payloadcms/live-preview-react": "^3.0.0",
74
86
  "@payloadcms/next": "^3.0.0",
75
87
  "@payloadcms/richtext-lexical": "^3.0.0",
76
88
  "@payloadcms/ui": "^3.0.0",
@@ -93,13 +105,11 @@
93
105
  ],
94
106
  "dependencies": {
95
107
  "@mui/material-nextjs": "^7.3.7",
96
- "@payloadcms/email-nodemailer": "3.65.0",
97
- "@payloadcms/live-preview-react": "3.65.0",
98
108
  "server-only": "^0.0.1"
99
109
  },
100
110
  "optionalDependencies": {
101
111
  "@qwickapps/logging": "^1.0.1",
102
- "@qwickapps/log-client": "1.0.0"
112
+ "@qwickapps/log-client": "workspace:*"
103
113
  },
104
114
  "author": "QwickApps <legal@qwickapps.com>",
105
115
  "license": "PolyForm-Shield-1.0.0",
@@ -110,13 +120,5 @@
110
120
  "homepage": "https://github.com/qwickapps/cms#readme",
111
121
  "publishConfig": {
112
122
  "access": "public"
113
- },
114
- "scripts": {
115
- "build": "tsc && npm run copy-styles",
116
- "copy-styles": "mkdir -p dist/styles dist/admin/components/styles && cp src/styles/*.css dist/styles/ 2>/dev/null || true && cp src/admin/components/styles/*.css dist/admin/components/styles/ 2>/dev/null || true",
117
- "dev": "tsc --watch",
118
- "clean": "rm -rf dist",
119
- "validate": "./qa/clean-install/validate.sh",
120
- "validate:safe": "test -f ./qa/clean-install/validate.sh && npm run validate || echo 'Validation skipped - qa scripts not available'"
121
123
  }
122
- }
124
+ }
File without changes
@@ -1,12 +0,0 @@
1
- /**
2
- * HeroSlideshows Collection
3
- *
4
- * Stores named slideshows composed of multiple hero slides.
5
- * Each slideshow can be fetched by ID or name and rendered with
6
- * the HeroSlideshow component from @qwickapps/react-framework.
7
- *
8
- * Copyright (c) 2025 QwickApps.com. All rights reserved.
9
- */
10
- import type { CollectionConfig } from 'payload';
11
- export declare const HeroSlideshows: CollectionConfig;
12
- //# sourceMappingURL=HeroSlideshows.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"HeroSlideshows.d.ts","sourceRoot":"","sources":["../../src/collections/HeroSlideshows.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEhD,eAAO,MAAM,cAAc,EAAE,gBAuJ5B,CAAC"}
@@ -1,162 +0,0 @@
1
- /**
2
- * HeroSlideshows Collection
3
- *
4
- * Stores named slideshows composed of multiple hero slides.
5
- * Each slideshow can be fetched by ID or name and rendered with
6
- * the HeroSlideshow component from @qwickapps/react-framework.
7
- *
8
- * Copyright (c) 2025 QwickApps.com. All rights reserved.
9
- */
10
- export const HeroSlideshows = {
11
- slug: 'hero-slideshows',
12
- admin: {
13
- useAsTitle: 'name',
14
- defaultColumns: ['name', 'slideCount', 'autoPlayInterval'],
15
- group: 'Content',
16
- description: 'Named hero slideshows. Fetch by ID or name and pass slides to the HeroSlideshow component.',
17
- },
18
- access: {
19
- read: () => true,
20
- create: ({ req }) => req.user?.role === 'admin',
21
- update: ({ req }) => req.user?.role === 'admin',
22
- delete: ({ req }) => req.user?.role === 'admin',
23
- },
24
- fields: [
25
- {
26
- name: 'name',
27
- type: 'text',
28
- required: true,
29
- unique: true,
30
- admin: {
31
- description: 'Internal identifier, e.g. "home-hero" or "about-hero"',
32
- },
33
- },
34
- {
35
- name: 'slides',
36
- type: 'array',
37
- required: true,
38
- minRows: 1,
39
- admin: {
40
- description: 'Slides displayed in order. Each slide is one full-width hero section.',
41
- },
42
- fields: [
43
- {
44
- name: 'title',
45
- type: 'text',
46
- required: true,
47
- },
48
- {
49
- name: 'subtitle',
50
- type: 'textarea',
51
- },
52
- {
53
- name: 'backgroundImage',
54
- type: 'upload',
55
- relationTo: 'media',
56
- admin: {
57
- description: 'Background image (takes priority over gradient)',
58
- },
59
- },
60
- {
61
- name: 'overlayOpacity',
62
- type: 'number',
63
- defaultValue: 0.5,
64
- admin: {
65
- description: 'Dark overlay on top of background image (0 = none, 1 = fully opaque)',
66
- step: 0.05,
67
- },
68
- },
69
- {
70
- name: 'backgroundGradient',
71
- type: 'text',
72
- admin: {
73
- description: 'CSS gradient, e.g. linear-gradient(135deg, #667eea 0%, #764ba2 100%)',
74
- },
75
- },
76
- {
77
- name: 'backgroundColor',
78
- type: 'select',
79
- defaultValue: 'primary',
80
- options: [
81
- { label: 'Primary theme color', value: 'primary' },
82
- { label: 'Secondary theme color', value: 'secondary' },
83
- { label: 'Surface', value: 'surface' },
84
- { label: 'Default', value: 'default' },
85
- ],
86
- admin: {
87
- description: 'Used when neither background image nor gradient is set',
88
- },
89
- },
90
- {
91
- name: 'actions',
92
- type: 'array',
93
- admin: {
94
- description: 'Call-to-action buttons',
95
- },
96
- fields: [
97
- {
98
- name: 'label',
99
- type: 'text',
100
- required: true,
101
- },
102
- {
103
- name: 'href',
104
- type: 'text',
105
- required: true,
106
- },
107
- {
108
- name: 'variant',
109
- type: 'select',
110
- defaultValue: 'primary',
111
- options: [
112
- { label: 'Primary (filled)', value: 'primary' },
113
- { label: 'Outlined', value: 'outlined' },
114
- { label: 'Text', value: 'text' },
115
- ],
116
- },
117
- {
118
- name: 'buttonSize',
119
- type: 'select',
120
- defaultValue: 'large',
121
- options: [
122
- { label: 'Small', value: 'small' },
123
- { label: 'Medium', value: 'medium' },
124
- { label: 'Large', value: 'large' },
125
- ],
126
- },
127
- ],
128
- },
129
- ],
130
- },
131
- {
132
- name: 'autoPlayInterval',
133
- type: 'number',
134
- defaultValue: 5000,
135
- admin: {
136
- description: 'Milliseconds between slide transitions. Set to 0 to disable auto-play.',
137
- },
138
- },
139
- {
140
- name: 'blockHeight',
141
- type: 'select',
142
- defaultValue: 'large',
143
- options: [
144
- { label: 'Small (300px)', value: 'small' },
145
- { label: 'Medium (400px)', value: 'medium' },
146
- { label: 'Large (600px)', value: 'large' },
147
- { label: 'Full viewport height', value: 'viewport' },
148
- ],
149
- },
150
- {
151
- name: 'textAlign',
152
- type: 'select',
153
- defaultValue: 'center',
154
- options: [
155
- { label: 'Left', value: 'left' },
156
- { label: 'Center', value: 'center' },
157
- { label: 'Right', value: 'right' },
158
- ],
159
- },
160
- ],
161
- };
162
- //# sourceMappingURL=HeroSlideshows.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"HeroSlideshows.js","sourceRoot":"","sources":["../../src/collections/HeroSlideshows.ts"],"names":[],"mappings":"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"}