@sociallane/elements 1.0.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.
Files changed (767) hide show
  1. package/.prettierignore +5 -0
  2. package/.prettierrc.json +8 -0
  3. package/.vite-dev +0 -0
  4. package/README.md +47 -0
  5. package/admin/js/widget-browser.js +124 -0
  6. package/admin/views/onboarding.php +62 -0
  7. package/admin/views/partials/category-tabs.php +39 -0
  8. package/admin/views/partials/step-complete.php +48 -0
  9. package/admin/views/partials/step-requirements.php +52 -0
  10. package/admin/views/partials/step-widgets.php +63 -0
  11. package/admin/views/partials/widget-card.php +67 -0
  12. package/admin/views/partials/widget-toolbar.php +28 -0
  13. package/admin/views/preview-embed.php +78 -0
  14. package/admin/views/preview-frame.php +183 -0
  15. package/admin/views/preview-index.php +74 -0
  16. package/admin/views/settings.php +94 -0
  17. package/admin/views/setup-widget-catalog-frontend.php +189 -0
  18. package/admin/views/setup-widget-catalog.php +164 -0
  19. package/assets/css/lenis.css +18 -0
  20. package/assets/css/tailwind.css +740 -0
  21. package/assets/dist/.vite/manifest.json +13 -0
  22. package/assets/dist/animations-BySooxN8.js +37 -0
  23. package/assets/dist/tailwind-DzIAfumJ.css +1 -0
  24. package/assets/js/animations.js +113 -0
  25. package/assets/js/utilities/hover-reveal.js +88 -0
  26. package/assets/js/utilities/pin.js +31 -0
  27. package/assets/js/utilities/reveal.js +59 -0
  28. package/assets/js/utilities/split-text.js +93 -0
  29. package/assets/js/utilities/stagger.js +48 -0
  30. package/assets/previews/.gitkeep +2 -0
  31. package/assets/previews/README.md +65 -0
  32. package/assets/svgs/components/accordion.svg +9 -0
  33. package/assets/svgs/components/alert.svg +6 -0
  34. package/assets/svgs/components/avatar.svg +4 -0
  35. package/assets/svgs/components/badge.svg +4 -0
  36. package/assets/svgs/components/breadcrumbs.svg +7 -0
  37. package/assets/svgs/components/button.svg +4 -0
  38. package/assets/svgs/components/calendar.svg +10 -0
  39. package/assets/svgs/components/card.svg +5 -0
  40. package/assets/svgs/widgets/bento-grid.svg +8 -0
  41. package/assets/svgs/widgets/bento-portfolio.svg +8 -0
  42. package/assets/svgs/widgets/content-block.svg +4 -0
  43. package/assets/svgs/widgets/faq.svg +11 -0
  44. package/assets/svgs/widgets/feature-grid.svg +14 -0
  45. package/assets/svgs/widgets/feature-list-cta.svg +10 -0
  46. package/assets/svgs/widgets/footer.svg +7 -0
  47. package/assets/svgs/widgets/grid-posts.svg +11 -0
  48. package/assets/svgs/widgets/grid-team.svg +8 -0
  49. package/assets/svgs/widgets/hero.svg +7 -0
  50. package/assets/svgs/widgets/intro-text.svg +3 -0
  51. package/assets/svgs/widgets/logo-grid.svg +12 -0
  52. package/assets/svgs/widgets/navigation.svg +10 -0
  53. package/assets/svgs/widgets/newsletter.svg +6 -0
  54. package/assets/svgs/widgets/pricing-table.svg +9 -0
  55. package/assets/svgs/widgets/social-proof.svg +7 -0
  56. package/docs/cursor-global-rule.md +24 -0
  57. package/docs/install-new-instance.md +92 -0
  58. package/docs/npm-widget-cheatsheet.md +178 -0
  59. package/docs/package-installation.md +127 -0
  60. package/docs/widgets/blog-grid.md +31 -0
  61. package/docs/widgets/card-hover-reveal.md +27 -0
  62. package/docs/widgets/cta-banner.md +31 -0
  63. package/docs/widgets/cta-split.md +26 -0
  64. package/docs/widgets/faq.md +31 -0
  65. package/docs/widgets/feature-list.md +21 -0
  66. package/docs/widgets/footer-links-contact.md +24 -0
  67. package/elements/.gitkeep +0 -0
  68. package/elements/button/button.php +161 -0
  69. package/elements/button/templates/render.php +89 -0
  70. package/elements/cta-group/templates/render.php +61 -0
  71. package/elements/image/image.php +113 -0
  72. package/elements/image/templates/render.php +43 -0
  73. package/elements/section-header/templates/render.php +103 -0
  74. package/includes/button-presets.php +71 -0
  75. package/includes/class-admin-settings.php +134 -0
  76. package/includes/class-disable-reset-css.php +78 -0
  77. package/includes/class-gravity-forms-styles.php +78 -0
  78. package/includes/class-onboarding.php +214 -0
  79. package/includes/class-setup-widget-catalog.php +37 -0
  80. package/includes/class-widget-manager.php +605 -0
  81. package/includes/class-widget-preview.php +101 -0
  82. package/includes/footer-menu-columns.php +85 -0
  83. package/includes/widget-preview-defaults.php +660 -0
  84. package/package.json +38 -0
  85. package/packages/core/assets/css/lenis.css +18 -0
  86. package/packages/core/assets/css/tailwind.css +704 -0
  87. package/packages/core/assets/dist/.vite/manifest.json +13 -0
  88. package/packages/core/assets/dist/animations-BySooxN8.js +37 -0
  89. package/packages/core/assets/dist/tailwind-BE97TLZW.css +1 -0
  90. package/packages/core/assets/js/animations.js +113 -0
  91. package/packages/core/assets/js/utilities/hover-reveal.js +88 -0
  92. package/packages/core/assets/js/utilities/pin.js +31 -0
  93. package/packages/core/assets/js/utilities/reveal.js +56 -0
  94. package/packages/core/assets/js/utilities/split-text.js +74 -0
  95. package/packages/core/assets/js/utilities/stagger.js +46 -0
  96. package/packages/core/includes/class-plugin.php +75 -0
  97. package/packages/core/includes/class-vite-assets.php +357 -0
  98. package/packages/core/includes/class-widgets-loader.php +195 -0
  99. package/packages/core/includes/helpers.php +407 -0
  100. package/packages/core/includes/traits/trait-animation-controls.php +194 -0
  101. package/packages/core/includes/traits/trait-common-controls.php +239 -0
  102. package/packages/core/package.json +25 -0
  103. package/packages/core/vite.config.js +123 -0
  104. package/packages/widgets/bento-grid/bento-grid.php +761 -0
  105. package/packages/widgets/bento-grid/data/view.php +327 -0
  106. package/packages/widgets/bento-grid/package.json +12 -0
  107. package/packages/widgets/bento-grid/templates/partials/cell1.php +45 -0
  108. package/packages/widgets/bento-grid/templates/partials/cell2.php +52 -0
  109. package/packages/widgets/bento-grid/templates/partials/cell3.php +45 -0
  110. package/packages/widgets/bento-grid/templates/partials/cell4.php +44 -0
  111. package/packages/widgets/bento-grid/templates/partials/default-grid.php +31 -0
  112. package/packages/widgets/bento-grid/templates/partials/tcsr-row1-left.php +68 -0
  113. package/packages/widgets/bento-grid/templates/partials/tcsr-row1-right.php +65 -0
  114. package/packages/widgets/bento-grid/templates/partials/tcsr-row2-center.php +41 -0
  115. package/packages/widgets/bento-grid/templates/partials/tcsr-row2-left.php +38 -0
  116. package/packages/widgets/bento-grid/templates/partials/tcsr-row2-right.php +38 -0
  117. package/packages/widgets/bento-grid/templates/partials/two-column-second-row-grid.php +35 -0
  118. package/packages/widgets/bento-grid/templates/partials/two-row-deploys.php +47 -0
  119. package/packages/widgets/bento-grid/templates/partials/two-row-grid.php +34 -0
  120. package/packages/widgets/bento-grid/templates/partials/two-row-integrations.php +40 -0
  121. package/packages/widgets/bento-grid/templates/partials/two-row-overview.php +67 -0
  122. package/packages/widgets/bento-grid/templates/partials/two-row-releases.php +29 -0
  123. package/packages/widgets/bento-grid/templates/partials/two-row-security.php +44 -0
  124. package/packages/widgets/bento-grid/templates/wrapper.php +72 -0
  125. package/packages/widgets/bento-grid-4/bento-grid-4.php +524 -0
  126. package/packages/widgets/bento-grid-4/data/view.php +127 -0
  127. package/packages/widgets/bento-grid-4/package.json +12 -0
  128. package/packages/widgets/bento-grid-4/templates/partials/cell1.php +45 -0
  129. package/packages/widgets/bento-grid-4/templates/partials/cell2.php +52 -0
  130. package/packages/widgets/bento-grid-4/templates/partials/cell3.php +45 -0
  131. package/packages/widgets/bento-grid-4/templates/partials/cell4.php +44 -0
  132. package/packages/widgets/bento-grid-4/templates/partials/default-grid.php +31 -0
  133. package/packages/widgets/bento-grid-4/templates/partials/tcsr-row1-left.php +68 -0
  134. package/packages/widgets/bento-grid-4/templates/partials/tcsr-row1-right.php +65 -0
  135. package/packages/widgets/bento-grid-4/templates/partials/tcsr-row2-center.php +41 -0
  136. package/packages/widgets/bento-grid-4/templates/partials/tcsr-row2-left.php +38 -0
  137. package/packages/widgets/bento-grid-4/templates/partials/tcsr-row2-right.php +38 -0
  138. package/packages/widgets/bento-grid-4/templates/partials/two-column-second-row-grid.php +35 -0
  139. package/packages/widgets/bento-grid-4/templates/partials/two-row-deploys.php +47 -0
  140. package/packages/widgets/bento-grid-4/templates/partials/two-row-grid.php +34 -0
  141. package/packages/widgets/bento-grid-4/templates/partials/two-row-integrations.php +40 -0
  142. package/packages/widgets/bento-grid-4/templates/partials/two-row-overview.php +67 -0
  143. package/packages/widgets/bento-grid-4/templates/partials/two-row-releases.php +29 -0
  144. package/packages/widgets/bento-grid-4/templates/partials/two-row-security.php +44 -0
  145. package/packages/widgets/bento-grid-4/templates/wrapper.php +65 -0
  146. package/packages/widgets/bento-grid-5/bento-grid-5.php +219 -0
  147. package/packages/widgets/bento-grid-5/data/view.php +136 -0
  148. package/packages/widgets/bento-grid-5/package.json +12 -0
  149. package/packages/widgets/bento-grid-5/templates/partials/cell1.php +45 -0
  150. package/packages/widgets/bento-grid-5/templates/partials/cell2.php +52 -0
  151. package/packages/widgets/bento-grid-5/templates/partials/cell3.php +45 -0
  152. package/packages/widgets/bento-grid-5/templates/partials/cell4.php +44 -0
  153. package/packages/widgets/bento-grid-5/templates/partials/default-grid.php +31 -0
  154. package/packages/widgets/bento-grid-5/templates/partials/tcsr-row1-left.php +68 -0
  155. package/packages/widgets/bento-grid-5/templates/partials/tcsr-row1-right.php +65 -0
  156. package/packages/widgets/bento-grid-5/templates/partials/tcsr-row2-center.php +41 -0
  157. package/packages/widgets/bento-grid-5/templates/partials/tcsr-row2-left.php +38 -0
  158. package/packages/widgets/bento-grid-5/templates/partials/tcsr-row2-right.php +38 -0
  159. package/packages/widgets/bento-grid-5/templates/partials/two-column-second-row-grid.php +35 -0
  160. package/packages/widgets/bento-grid-5/templates/partials/two-row-deploys.php +47 -0
  161. package/packages/widgets/bento-grid-5/templates/partials/two-row-grid.php +34 -0
  162. package/packages/widgets/bento-grid-5/templates/partials/two-row-integrations.php +40 -0
  163. package/packages/widgets/bento-grid-5/templates/partials/two-row-overview.php +67 -0
  164. package/packages/widgets/bento-grid-5/templates/partials/two-row-releases.php +29 -0
  165. package/packages/widgets/bento-grid-5/templates/partials/two-row-security.php +44 -0
  166. package/packages/widgets/bento-grid-5/templates/wrapper.php +65 -0
  167. package/packages/widgets/bento-grid-6/bento-grid-6.php +223 -0
  168. package/packages/widgets/bento-grid-6/data/view.php +158 -0
  169. package/packages/widgets/bento-grid-6/package.json +12 -0
  170. package/packages/widgets/bento-grid-6/templates/partials/cell1.php +45 -0
  171. package/packages/widgets/bento-grid-6/templates/partials/cell2.php +52 -0
  172. package/packages/widgets/bento-grid-6/templates/partials/cell3.php +45 -0
  173. package/packages/widgets/bento-grid-6/templates/partials/cell4.php +44 -0
  174. package/packages/widgets/bento-grid-6/templates/partials/default-grid.php +31 -0
  175. package/packages/widgets/bento-grid-6/templates/partials/tcsr-row1-left.php +68 -0
  176. package/packages/widgets/bento-grid-6/templates/partials/tcsr-row1-right.php +65 -0
  177. package/packages/widgets/bento-grid-6/templates/partials/tcsr-row2-center.php +41 -0
  178. package/packages/widgets/bento-grid-6/templates/partials/tcsr-row2-left.php +38 -0
  179. package/packages/widgets/bento-grid-6/templates/partials/tcsr-row2-right.php +38 -0
  180. package/packages/widgets/bento-grid-6/templates/partials/two-column-second-row-grid.php +35 -0
  181. package/packages/widgets/bento-grid-6/templates/partials/two-row-deploys.php +47 -0
  182. package/packages/widgets/bento-grid-6/templates/partials/two-row-grid.php +34 -0
  183. package/packages/widgets/bento-grid-6/templates/partials/two-row-integrations.php +40 -0
  184. package/packages/widgets/bento-grid-6/templates/partials/two-row-overview.php +67 -0
  185. package/packages/widgets/bento-grid-6/templates/partials/two-row-releases.php +29 -0
  186. package/packages/widgets/bento-grid-6/templates/partials/two-row-security.php +44 -0
  187. package/packages/widgets/bento-grid-6/templates/wrapper.php +65 -0
  188. package/packages/widgets/bento-portfolio/bento-portfolio.php +399 -0
  189. package/packages/widgets/bento-portfolio/data/view.php +102 -0
  190. package/packages/widgets/bento-portfolio/package.json +12 -0
  191. package/packages/widgets/bento-portfolio/templates/partials/portfolio-card.php +84 -0
  192. package/packages/widgets/bento-portfolio/templates/partials/portfolio-default-grid.php +35 -0
  193. package/packages/widgets/bento-portfolio/templates/partials/portfolio-two-column-second-row-grid.php +39 -0
  194. package/packages/widgets/bento-portfolio/templates/partials/portfolio-two-row-grid.php +35 -0
  195. package/packages/widgets/bento-portfolio/templates/wrapper.php +88 -0
  196. package/packages/widgets/bento-portfolio-4/bento-portfolio-4.php +382 -0
  197. package/packages/widgets/bento-portfolio-4/data/view.php +91 -0
  198. package/packages/widgets/bento-portfolio-4/package.json +12 -0
  199. package/packages/widgets/bento-portfolio-4/templates/partials/portfolio-card.php +84 -0
  200. package/packages/widgets/bento-portfolio-4/templates/partials/portfolio-default-grid.php +35 -0
  201. package/packages/widgets/bento-portfolio-4/templates/partials/portfolio-two-column-second-row-grid.php +39 -0
  202. package/packages/widgets/bento-portfolio-4/templates/partials/portfolio-two-row-grid.php +35 -0
  203. package/packages/widgets/bento-portfolio-4/templates/wrapper.php +78 -0
  204. package/packages/widgets/bento-portfolio-5/bento-portfolio-5.php +382 -0
  205. package/packages/widgets/bento-portfolio-5/data/view.php +91 -0
  206. package/packages/widgets/bento-portfolio-5/package.json +12 -0
  207. package/packages/widgets/bento-portfolio-5/templates/partials/portfolio-card.php +84 -0
  208. package/packages/widgets/bento-portfolio-5/templates/partials/portfolio-default-grid.php +35 -0
  209. package/packages/widgets/bento-portfolio-5/templates/partials/portfolio-two-column-second-row-grid.php +39 -0
  210. package/packages/widgets/bento-portfolio-5/templates/partials/portfolio-two-row-grid.php +35 -0
  211. package/packages/widgets/bento-portfolio-5/templates/wrapper.php +78 -0
  212. package/packages/widgets/bento-portfolio-6/bento-portfolio-6.php +382 -0
  213. package/packages/widgets/bento-portfolio-6/data/view.php +91 -0
  214. package/packages/widgets/bento-portfolio-6/package.json +12 -0
  215. package/packages/widgets/bento-portfolio-6/templates/partials/portfolio-card.php +84 -0
  216. package/packages/widgets/bento-portfolio-6/templates/partials/portfolio-default-grid.php +35 -0
  217. package/packages/widgets/bento-portfolio-6/templates/partials/portfolio-two-column-second-row-grid.php +39 -0
  218. package/packages/widgets/bento-portfolio-6/templates/partials/portfolio-two-row-grid.php +35 -0
  219. package/packages/widgets/bento-portfolio-6/templates/wrapper.php +78 -0
  220. package/packages/widgets/blog-grid/blog-grid.php +359 -0
  221. package/packages/widgets/blog-grid/data/view.php +192 -0
  222. package/packages/widgets/blog-grid/package.json +12 -0
  223. package/packages/widgets/blog-grid/templates/partials/card.php +73 -0
  224. package/packages/widgets/blog-grid/templates/wrapper.php +89 -0
  225. package/packages/widgets/card-hover-reveal/card-hover-reveal.php +329 -0
  226. package/packages/widgets/card-hover-reveal/data/view.php +108 -0
  227. package/packages/widgets/card-hover-reveal/package.json +12 -0
  228. package/packages/widgets/card-hover-reveal/templates/partials/card.php +86 -0
  229. package/packages/widgets/card-hover-reveal/templates/wrapper.php +80 -0
  230. package/packages/widgets/client-logos/client-logos.php +214 -0
  231. package/packages/widgets/client-logos/data/view.php +88 -0
  232. package/packages/widgets/client-logos/package.json +12 -0
  233. package/packages/widgets/client-logos/templates/partials/client-item.php +38 -0
  234. package/packages/widgets/client-logos/templates/wrapper.php +62 -0
  235. package/packages/widgets/content-block/content-block.php +280 -0
  236. package/packages/widgets/content-block/data/view.php +103 -0
  237. package/packages/widgets/content-block/package.json +12 -0
  238. package/packages/widgets/content-block/templates/partials/content.php +52 -0
  239. package/packages/widgets/content-block/templates/wrapper.php +73 -0
  240. package/packages/widgets/cta-banner/cta-banner.php +300 -0
  241. package/packages/widgets/cta-banner/data/view.php +96 -0
  242. package/packages/widgets/cta-banner/package.json +12 -0
  243. package/packages/widgets/cta-banner/templates/wrapper.php +131 -0
  244. package/packages/widgets/cta-notify/cta-notify.php +135 -0
  245. package/packages/widgets/cta-notify/data/view.php +48 -0
  246. package/packages/widgets/cta-notify/package.json +12 -0
  247. package/packages/widgets/cta-notify/templates/wrapper.php +69 -0
  248. package/packages/widgets/cta-split/cta-split.php +246 -0
  249. package/packages/widgets/cta-split/data/view.php +84 -0
  250. package/packages/widgets/cta-split/package.json +12 -0
  251. package/packages/widgets/cta-split/templates/wrapper.php +113 -0
  252. package/packages/widgets/faq-centered/data/view.php +87 -0
  253. package/packages/widgets/faq-centered/faq-centered.php +223 -0
  254. package/packages/widgets/faq-centered/package.json +12 -0
  255. package/packages/widgets/faq-centered/templates/partials/accordion.php +70 -0
  256. package/packages/widgets/faq-centered/templates/partials/layout-centered.php +41 -0
  257. package/packages/widgets/faq-centered/templates/partials/layout-split.php +47 -0
  258. package/packages/widgets/faq-centered/templates/partials/layout-stacked.php +57 -0
  259. package/packages/widgets/faq-centered/templates/wrapper.php +70 -0
  260. package/packages/widgets/faq-split/data/view.php +93 -0
  261. package/packages/widgets/faq-split/faq-split.php +236 -0
  262. package/packages/widgets/faq-split/package.json +12 -0
  263. package/packages/widgets/faq-split/templates/partials/accordion.php +70 -0
  264. package/packages/widgets/faq-split/templates/partials/layout-centered.php +41 -0
  265. package/packages/widgets/faq-split/templates/partials/layout-split.php +47 -0
  266. package/packages/widgets/faq-split/templates/partials/layout-stacked.php +57 -0
  267. package/packages/widgets/faq-split/templates/wrapper.php +70 -0
  268. package/packages/widgets/faq-stacked/data/view.php +92 -0
  269. package/packages/widgets/faq-stacked/faq-stacked.php +223 -0
  270. package/packages/widgets/faq-stacked/package.json +12 -0
  271. package/packages/widgets/faq-stacked/templates/partials/accordion.php +70 -0
  272. package/packages/widgets/faq-stacked/templates/partials/layout-centered.php +41 -0
  273. package/packages/widgets/faq-stacked/templates/partials/layout-split.php +47 -0
  274. package/packages/widgets/faq-stacked/templates/partials/layout-stacked.php +57 -0
  275. package/packages/widgets/faq-stacked/templates/wrapper.php +70 -0
  276. package/packages/widgets/feature-grid/data/view.php +80 -0
  277. package/packages/widgets/feature-grid/feature-grid.php +305 -0
  278. package/packages/widgets/feature-grid/package.json +12 -0
  279. package/packages/widgets/feature-grid/templates/partials/centered-2x2.php +69 -0
  280. package/packages/widgets/feature-grid/templates/partials/feature-item.php +54 -0
  281. package/packages/widgets/feature-grid/templates/wrapper.php +67 -0
  282. package/packages/widgets/feature-grid-centered/data/view.php +78 -0
  283. package/packages/widgets/feature-grid-centered/feature-grid-centered.php +278 -0
  284. package/packages/widgets/feature-grid-centered/package.json +12 -0
  285. package/packages/widgets/feature-grid-centered/templates/partials/centered-2x2.php +69 -0
  286. package/packages/widgets/feature-grid-centered/templates/partials/feature-item.php +54 -0
  287. package/packages/widgets/feature-grid-centered/templates/wrapper.php +35 -0
  288. package/packages/widgets/feature-list/data/view.php +49 -0
  289. package/packages/widgets/feature-list/feature-list.php +160 -0
  290. package/packages/widgets/feature-list/package.json +12 -0
  291. package/packages/widgets/feature-list/templates/wrapper.php +69 -0
  292. package/packages/widgets/feature-list-cta/data/view.php +62 -0
  293. package/packages/widgets/feature-list-cta/feature-list-cta.php +226 -0
  294. package/packages/widgets/feature-list-cta/package.json +12 -0
  295. package/packages/widgets/feature-list-cta/templates/partials/feature-item.php +49 -0
  296. package/packages/widgets/feature-list-cta/templates/wrapper.php +65 -0
  297. package/packages/widgets/footer/data/view.php +133 -0
  298. package/packages/widgets/footer/footer.php +389 -0
  299. package/packages/widgets/footer/package.json +12 -0
  300. package/packages/widgets/footer/templates/partials/bottom.php +77 -0
  301. package/packages/widgets/footer/templates/partials/cta.php +47 -0
  302. package/packages/widgets/footer/templates/partials/link-columns.php +52 -0
  303. package/packages/widgets/footer/templates/wrapper.php +53 -0
  304. package/packages/widgets/footer-brand/data/view.php +130 -0
  305. package/packages/widgets/footer-brand/footer-brand.php +278 -0
  306. package/packages/widgets/footer-brand/package.json +12 -0
  307. package/packages/widgets/footer-brand/templates/partials/brand.php +69 -0
  308. package/packages/widgets/footer-brand/templates/partials/link-columns.php +51 -0
  309. package/packages/widgets/footer-brand/templates/wrapper.php +59 -0
  310. package/packages/widgets/footer-links-contact/data/view.php +145 -0
  311. package/packages/widgets/footer-links-contact/footer-links-contact.php +361 -0
  312. package/packages/widgets/footer-links-contact/package.json +12 -0
  313. package/packages/widgets/footer-links-contact/templates/partials/bottom.php +70 -0
  314. package/packages/widgets/footer-links-contact/templates/partials/contact-column.php +66 -0
  315. package/packages/widgets/footer-links-contact/templates/partials/link-column.php +39 -0
  316. package/packages/widgets/footer-links-contact/templates/partials/logo-column.php +46 -0
  317. package/packages/widgets/footer-links-contact/templates/wrapper.php +68 -0
  318. package/packages/widgets/form-contact/data/view.php +96 -0
  319. package/packages/widgets/form-contact/form-contact.php +274 -0
  320. package/packages/widgets/form-contact/package.json +12 -0
  321. package/packages/widgets/form-contact/templates/partials/testimonial.php +83 -0
  322. package/packages/widgets/form-contact/templates/wrapper.php +98 -0
  323. package/packages/widgets/grid-case-studies/data/view.php +74 -0
  324. package/packages/widgets/grid-case-studies/grid-case-studies.php +262 -0
  325. package/packages/widgets/grid-case-studies/package.json +12 -0
  326. package/packages/widgets/grid-case-studies/templates/partials/card.php +66 -0
  327. package/packages/widgets/grid-case-studies/templates/wrapper.php +69 -0
  328. package/packages/widgets/grid-components/data/view.php +107 -0
  329. package/packages/widgets/grid-components/grid-components.php +323 -0
  330. package/packages/widgets/grid-components/package.json +12 -0
  331. package/packages/widgets/grid-components/templates/partials/component-card.php +81 -0
  332. package/packages/widgets/grid-components/templates/wrapper.php +55 -0
  333. package/packages/widgets/grid-team/data/view.php +67 -0
  334. package/packages/widgets/grid-team/grid-team.php +201 -0
  335. package/packages/widgets/grid-team/package.json +12 -0
  336. package/packages/widgets/grid-team/templates/partials/team-card.php +52 -0
  337. package/packages/widgets/grid-team/templates/wrapper.php +67 -0
  338. package/packages/widgets/hero-announcement/data/view.php +96 -0
  339. package/packages/widgets/hero-announcement/hero-announcement.php +270 -0
  340. package/packages/widgets/hero-announcement/package.json +12 -0
  341. package/packages/widgets/hero-announcement/templates/wrapper.php +111 -0
  342. package/packages/widgets/hero-centered-image/data/view.php +119 -0
  343. package/packages/widgets/hero-centered-image/hero-centered-image.php +297 -0
  344. package/packages/widgets/hero-centered-image/package.json +12 -0
  345. package/packages/widgets/hero-centered-image/templates/wrapper.php +123 -0
  346. package/packages/widgets/hero-collage/data/view.php +108 -0
  347. package/packages/widgets/hero-collage/hero-collage.php +151 -0
  348. package/packages/widgets/hero-collage/package.json +12 -0
  349. package/packages/widgets/hero-collage/templates/wrapper.php +102 -0
  350. package/packages/widgets/hero-overlay/data/view.php +117 -0
  351. package/packages/widgets/hero-overlay/hero-overlay.php +277 -0
  352. package/packages/widgets/hero-overlay/package.json +12 -0
  353. package/packages/widgets/hero-overlay/templates/wrapper.php +225 -0
  354. package/packages/widgets/hero-overlay-single/data/view.php +118 -0
  355. package/packages/widgets/hero-overlay-single/hero-overlay-single.php +221 -0
  356. package/packages/widgets/hero-overlay-single/package.json +12 -0
  357. package/packages/widgets/hero-overlay-single/templates/wrapper.php +225 -0
  358. package/packages/widgets/hero-overlay-slider/data/view.php +118 -0
  359. package/packages/widgets/hero-overlay-slider/hero-overlay-slider.php +262 -0
  360. package/packages/widgets/hero-overlay-slider/package.json +12 -0
  361. package/packages/widgets/hero-overlay-slider/templates/wrapper.php +225 -0
  362. package/packages/widgets/hero-saas-centered/data/view.php +79 -0
  363. package/packages/widgets/hero-saas-centered/hero-saas-centered.php +145 -0
  364. package/packages/widgets/hero-saas-centered/package.json +12 -0
  365. package/packages/widgets/hero-saas-centered/templates/partials/layout-centered.php +70 -0
  366. package/packages/widgets/hero-saas-centered/templates/partials/layout-split.php +76 -0
  367. package/packages/widgets/hero-saas-centered/templates/partials/layout-stacked.php +70 -0
  368. package/packages/widgets/hero-saas-centered/templates/wrapper.php +46 -0
  369. package/packages/widgets/hero-saas-split/data/view.php +83 -0
  370. package/packages/widgets/hero-saas-split/hero-saas-split.php +158 -0
  371. package/packages/widgets/hero-saas-split/package.json +12 -0
  372. package/packages/widgets/hero-saas-split/templates/partials/layout-centered.php +70 -0
  373. package/packages/widgets/hero-saas-split/templates/partials/layout-split.php +76 -0
  374. package/packages/widgets/hero-saas-split/templates/partials/layout-stacked.php +70 -0
  375. package/packages/widgets/hero-saas-split/templates/wrapper.php +46 -0
  376. package/packages/widgets/hero-saas-stacked/data/view.php +79 -0
  377. package/packages/widgets/hero-saas-stacked/hero-saas-stacked.php +145 -0
  378. package/packages/widgets/hero-saas-stacked/package.json +12 -0
  379. package/packages/widgets/hero-saas-stacked/templates/partials/layout-centered.php +70 -0
  380. package/packages/widgets/hero-saas-stacked/templates/partials/layout-split.php +76 -0
  381. package/packages/widgets/hero-saas-stacked/templates/partials/layout-stacked.php +70 -0
  382. package/packages/widgets/hero-saas-stacked/templates/wrapper.php +46 -0
  383. package/packages/widgets/hero-split/data/view.php +84 -0
  384. package/packages/widgets/hero-split/hero-split.php +127 -0
  385. package/packages/widgets/hero-split/package.json +12 -0
  386. package/packages/widgets/hero-split/templates/wrapper.php +86 -0
  387. package/packages/widgets/hero-stacked-image/data/view.php +137 -0
  388. package/packages/widgets/hero-stacked-image/hero-stacked-image.php +248 -0
  389. package/packages/widgets/hero-stacked-image/package.json +12 -0
  390. package/packages/widgets/hero-stacked-image/templates/wrapper.php +176 -0
  391. package/packages/widgets/intro-pattern/data/view.php +64 -0
  392. package/packages/widgets/intro-pattern/intro-pattern.php +161 -0
  393. package/packages/widgets/intro-pattern/package.json +12 -0
  394. package/packages/widgets/intro-pattern/templates/wrapper.php +61 -0
  395. package/packages/widgets/intro-text/data/view.php +79 -0
  396. package/packages/widgets/intro-text/intro-text.php +252 -0
  397. package/packages/widgets/intro-text/package.json +12 -0
  398. package/packages/widgets/intro-text/templates/wrapper.php +75 -0
  399. package/packages/widgets/logo-grid-centered/data/view.php +79 -0
  400. package/packages/widgets/logo-grid-centered/logo-grid-centered.php +254 -0
  401. package/packages/widgets/logo-grid-centered/package.json +12 -0
  402. package/packages/widgets/logo-grid-centered/templates/wrapper.php +95 -0
  403. package/packages/widgets/logo-grid-row/data/view.php +79 -0
  404. package/packages/widgets/logo-grid-row/logo-grid-row.php +254 -0
  405. package/packages/widgets/logo-grid-row/package.json +12 -0
  406. package/packages/widgets/logo-grid-row/templates/wrapper.php +108 -0
  407. package/packages/widgets/logo-grid-split/data/view.php +79 -0
  408. package/packages/widgets/logo-grid-split/logo-grid-split.php +254 -0
  409. package/packages/widgets/logo-grid-split/package.json +12 -0
  410. package/packages/widgets/logo-grid-split/templates/wrapper.php +97 -0
  411. package/packages/widgets/nav-centered/data/view.php +253 -0
  412. package/packages/widgets/nav-centered/nav-centered.php +350 -0
  413. package/packages/widgets/nav-centered/package.json +12 -0
  414. package/packages/widgets/nav-centered/templates/partials/desktop-mega-panel.php +109 -0
  415. package/packages/widgets/nav-centered/templates/partials/desktop-menu.php +102 -0
  416. package/packages/widgets/nav-centered/templates/partials/mobile-menu.php +104 -0
  417. package/packages/widgets/nav-centered/templates/wrapper.php +401 -0
  418. package/packages/widgets/nav-compact/data/view.php +253 -0
  419. package/packages/widgets/nav-compact/nav-compact.php +350 -0
  420. package/packages/widgets/nav-compact/package.json +12 -0
  421. package/packages/widgets/nav-compact/templates/partials/desktop-mega-panel.php +109 -0
  422. package/packages/widgets/nav-compact/templates/partials/desktop-menu.php +102 -0
  423. package/packages/widgets/nav-compact/templates/partials/mobile-menu.php +104 -0
  424. package/packages/widgets/nav-compact/templates/wrapper.php +401 -0
  425. package/packages/widgets/nav-default/data/view.php +254 -0
  426. package/packages/widgets/nav-default/nav-default.php +350 -0
  427. package/packages/widgets/nav-default/package.json +12 -0
  428. package/packages/widgets/nav-default/templates/partials/desktop-mega-panel.php +109 -0
  429. package/packages/widgets/nav-default/templates/partials/desktop-menu.php +102 -0
  430. package/packages/widgets/nav-default/templates/partials/mobile-menu.php +104 -0
  431. package/packages/widgets/nav-default/templates/wrapper.php +401 -0
  432. package/packages/widgets/nav-floating/data/view.php +253 -0
  433. package/packages/widgets/nav-floating/nav-floating.php +350 -0
  434. package/packages/widgets/nav-floating/package.json +12 -0
  435. package/packages/widgets/nav-floating/templates/partials/desktop-mega-panel.php +109 -0
  436. package/packages/widgets/nav-floating/templates/partials/desktop-menu.php +102 -0
  437. package/packages/widgets/nav-floating/templates/partials/mobile-menu.php +104 -0
  438. package/packages/widgets/nav-floating/templates/wrapper.php +401 -0
  439. package/packages/widgets/nav-minimal/data/view.php +253 -0
  440. package/packages/widgets/nav-minimal/nav-minimal.php +350 -0
  441. package/packages/widgets/nav-minimal/package.json +12 -0
  442. package/packages/widgets/nav-minimal/templates/partials/desktop-mega-panel.php +109 -0
  443. package/packages/widgets/nav-minimal/templates/partials/desktop-menu.php +102 -0
  444. package/packages/widgets/nav-minimal/templates/partials/mobile-menu.php +104 -0
  445. package/packages/widgets/nav-minimal/templates/wrapper.php +401 -0
  446. package/packages/widgets/newsletter/data/view.php +56 -0
  447. package/packages/widgets/newsletter/newsletter.php +210 -0
  448. package/packages/widgets/newsletter/package.json +12 -0
  449. package/packages/widgets/newsletter/templates/wrapper.php +137 -0
  450. package/packages/widgets/newsletter-card/data/view.php +55 -0
  451. package/packages/widgets/newsletter-card/newsletter-card.php +184 -0
  452. package/packages/widgets/newsletter-card/package.json +12 -0
  453. package/packages/widgets/newsletter-card/templates/wrapper.php +90 -0
  454. package/packages/widgets/newsletter-section/data/view.php +55 -0
  455. package/packages/widgets/newsletter-section/newsletter-section.php +184 -0
  456. package/packages/widgets/newsletter-section/package.json +12 -0
  457. package/packages/widgets/newsletter-section/templates/wrapper.php +87 -0
  458. package/packages/widgets/outreach-dashboard/data/view.php +176 -0
  459. package/packages/widgets/outreach-dashboard/outreach-dashboard.php +504 -0
  460. package/packages/widgets/outreach-dashboard/package.json +12 -0
  461. package/packages/widgets/outreach-dashboard/templates/partials/card-chat.php +69 -0
  462. package/packages/widgets/outreach-dashboard/templates/partials/card-engagement.php +60 -0
  463. package/packages/widgets/outreach-dashboard/templates/partials/card-integrations.php +39 -0
  464. package/packages/widgets/outreach-dashboard/templates/partials/card-meetings.php +43 -0
  465. package/packages/widgets/outreach-dashboard/templates/partials/card-networking.php +28 -0
  466. package/packages/widgets/outreach-dashboard/templates/wrapper.php +76 -0
  467. package/packages/widgets/page-hero-center/data/view.php +43 -0
  468. package/packages/widgets/page-hero-center/package.json +12 -0
  469. package/packages/widgets/page-hero-center/page-hero-center.php +120 -0
  470. package/packages/widgets/page-hero-center/templates/wrapper.php +54 -0
  471. package/packages/widgets/page-hero-left/data/view.php +43 -0
  472. package/packages/widgets/page-hero-left/package.json +12 -0
  473. package/packages/widgets/page-hero-left/page-hero-left.php +120 -0
  474. package/packages/widgets/page-hero-left/templates/wrapper.php +54 -0
  475. package/packages/widgets/pipeline-dashboard/data/view.php +131 -0
  476. package/packages/widgets/pipeline-dashboard/package.json +12 -0
  477. package/packages/widgets/pipeline-dashboard/pipeline-dashboard.php +407 -0
  478. package/packages/widgets/pipeline-dashboard/templates/partials/app-bar.php +31 -0
  479. package/packages/widgets/pipeline-dashboard/templates/partials/kanban.php +56 -0
  480. package/packages/widgets/pipeline-dashboard/templates/partials/pipeline-header.php +66 -0
  481. package/packages/widgets/pipeline-dashboard/templates/wrapper.php +64 -0
  482. package/packages/widgets/posts-grid/data/view.php +144 -0
  483. package/packages/widgets/posts-grid/package.json +12 -0
  484. package/packages/widgets/posts-grid/posts-grid.php +282 -0
  485. package/packages/widgets/posts-grid/templates/partials/card-overlay.php +58 -0
  486. package/packages/widgets/posts-grid/templates/partials/card.php +49 -0
  487. package/packages/widgets/posts-grid/templates/wrapper.php +55 -0
  488. package/packages/widgets/posts-grid-overlay/data/view.php +144 -0
  489. package/packages/widgets/posts-grid-overlay/package.json +12 -0
  490. package/packages/widgets/posts-grid-overlay/posts-grid-overlay.php +282 -0
  491. package/packages/widgets/posts-grid-overlay/templates/partials/card-overlay.php +58 -0
  492. package/packages/widgets/posts-grid-overlay/templates/partials/card.php +49 -0
  493. package/packages/widgets/posts-grid-overlay/templates/wrapper.php +55 -0
  494. package/packages/widgets/pricing-table/data/view.php +96 -0
  495. package/packages/widgets/pricing-table/package.json +12 -0
  496. package/packages/widgets/pricing-table/pricing-table.php +376 -0
  497. package/packages/widgets/pricing-table/templates/partials/pricing-card.php +125 -0
  498. package/packages/widgets/pricing-table/templates/wrapper.php +164 -0
  499. package/packages/widgets/sales-dashboard/data/view.php +158 -0
  500. package/packages/widgets/sales-dashboard/package.json +12 -0
  501. package/packages/widgets/sales-dashboard/sales-dashboard.php +434 -0
  502. package/packages/widgets/sales-dashboard/templates/partials/card-competitors.php +78 -0
  503. package/packages/widgets/sales-dashboard/templates/partials/card-feature.php +58 -0
  504. package/packages/widgets/sales-dashboard/templates/partials/card-profile.php +76 -0
  505. package/packages/widgets/sales-dashboard/templates/wrapper.php +74 -0
  506. package/packages/widgets/section-stats/data/view.php +90 -0
  507. package/packages/widgets/section-stats/package.json +12 -0
  508. package/packages/widgets/section-stats/section-stats.php +232 -0
  509. package/packages/widgets/section-stats/templates/partials/stat-card.php +44 -0
  510. package/packages/widgets/section-stats/templates/wrapper.php +87 -0
  511. package/packages/widgets/services/data/view.php +79 -0
  512. package/packages/widgets/services/package.json +12 -0
  513. package/packages/widgets/services/services.php +198 -0
  514. package/packages/widgets/services/templates/partials/service-item.php +35 -0
  515. package/packages/widgets/services/templates/wrapper.php +92 -0
  516. package/packages/widgets/simple-page-hero/data/view.php +43 -0
  517. package/packages/widgets/simple-page-hero/package.json +12 -0
  518. package/packages/widgets/simple-page-hero/simple-page-hero.php +147 -0
  519. package/packages/widgets/simple-page-hero/templates/wrapper.php +54 -0
  520. package/packages/widgets/social-proof/data/view.php +62 -0
  521. package/packages/widgets/social-proof/package.json +12 -0
  522. package/packages/widgets/social-proof/social-proof.php +271 -0
  523. package/packages/widgets/social-proof/templates/partials/layout-trust.php +73 -0
  524. package/packages/widgets/social-proof/templates/partials/stat-card.php +32 -0
  525. package/packages/widgets/social-proof/templates/partials/stat-item.php +35 -0
  526. package/packages/widgets/social-proof/templates/wrapper.php +87 -0
  527. package/packages/widgets/social-proof-trust/data/view.php +105 -0
  528. package/packages/widgets/social-proof-trust/package.json +12 -0
  529. package/packages/widgets/social-proof-trust/social-proof-trust.php +367 -0
  530. package/packages/widgets/social-proof-trust/templates/partials/layout-trust.php +73 -0
  531. package/packages/widgets/social-proof-trust/templates/partials/stat-card.php +32 -0
  532. package/packages/widgets/social-proof-trust/templates/partials/stat-item.php +35 -0
  533. package/packages/widgets/social-proof-trust/templates/wrapper.php +48 -0
  534. package/packages/widgets/testimonial-quote/data/view.php +57 -0
  535. package/packages/widgets/testimonial-quote/package.json +12 -0
  536. package/packages/widgets/testimonial-quote/templates/wrapper.php +66 -0
  537. package/packages/widgets/testimonial-quote/testimonial-quote.php +157 -0
  538. package/packages/widgets/testimonials-bento/data/view.php +110 -0
  539. package/packages/widgets/testimonials-bento/package.json +12 -0
  540. package/packages/widgets/testimonials-bento/templates/partials/layout-bento.php +36 -0
  541. package/packages/widgets/testimonials-bento/templates/partials/layout-masonry.php +74 -0
  542. package/packages/widgets/testimonials-bento/templates/partials/testimonial-card.php +85 -0
  543. package/packages/widgets/testimonials-bento/templates/wrapper.php +63 -0
  544. package/packages/widgets/testimonials-bento/testimonials-bento.php +322 -0
  545. package/packages/widgets/testimonials-grid/data/view.php +108 -0
  546. package/packages/widgets/testimonials-grid/package.json +12 -0
  547. package/packages/widgets/testimonials-grid/templates/partials/layout-bento.php +36 -0
  548. package/packages/widgets/testimonials-grid/templates/partials/layout-masonry.php +74 -0
  549. package/packages/widgets/testimonials-grid/templates/partials/testimonial-card.php +85 -0
  550. package/packages/widgets/testimonials-grid/templates/wrapper.php +74 -0
  551. package/packages/widgets/testimonials-grid/testimonials-grid.php +336 -0
  552. package/packages/widgets/testimonials-masonry/data/view.php +108 -0
  553. package/packages/widgets/testimonials-masonry/package.json +12 -0
  554. package/packages/widgets/testimonials-masonry/templates/partials/layout-bento.php +36 -0
  555. package/packages/widgets/testimonials-masonry/templates/partials/layout-masonry.php +74 -0
  556. package/packages/widgets/testimonials-masonry/templates/partials/testimonial-card.php +85 -0
  557. package/packages/widgets/testimonials-masonry/templates/wrapper.php +63 -0
  558. package/packages/widgets/testimonials-masonry/testimonials-masonry.php +336 -0
  559. package/packages/widgets/widget-filter/data/view.php +527 -0
  560. package/packages/widgets/widget-filter/package.json +12 -0
  561. package/packages/widgets/widget-filter/templates/wrapper.php +630 -0
  562. package/packages/widgets/widget-filter/widget-filter.php +123 -0
  563. package/scripts/scaffold-widget-packages.js +109 -0
  564. package/scripts/setup.sh +56 -0
  565. package/scripts/split-widget.js +176 -0
  566. package/scripts/sync-widgets.js +69 -0
  567. package/sociallane-elements.php +104 -0
  568. package/vite.config.js +129 -0
  569. package/widgets/.gitkeep +0 -0
  570. package/widgets/bento-grid/bento-grid.php +761 -0
  571. package/widgets/bento-grid/data/view.php +334 -0
  572. package/widgets/bento-grid/templates/partials/cell1.php +45 -0
  573. package/widgets/bento-grid/templates/partials/cell2.php +52 -0
  574. package/widgets/bento-grid/templates/partials/cell3.php +45 -0
  575. package/widgets/bento-grid/templates/partials/cell4.php +44 -0
  576. package/widgets/bento-grid/templates/partials/default-grid.php +31 -0
  577. package/widgets/bento-grid/templates/partials/tcsr-row1-left.php +68 -0
  578. package/widgets/bento-grid/templates/partials/tcsr-row1-right.php +65 -0
  579. package/widgets/bento-grid/templates/partials/tcsr-row2-center.php +41 -0
  580. package/widgets/bento-grid/templates/partials/tcsr-row2-left.php +38 -0
  581. package/widgets/bento-grid/templates/partials/tcsr-row2-right.php +38 -0
  582. package/widgets/bento-grid/templates/partials/two-column-second-row-grid.php +35 -0
  583. package/widgets/bento-grid/templates/partials/two-row-deploys.php +47 -0
  584. package/widgets/bento-grid/templates/partials/two-row-grid.php +34 -0
  585. package/widgets/bento-grid/templates/partials/two-row-integrations.php +40 -0
  586. package/widgets/bento-grid/templates/partials/two-row-overview.php +67 -0
  587. package/widgets/bento-grid/templates/partials/two-row-releases.php +29 -0
  588. package/widgets/bento-grid/templates/partials/two-row-security.php +44 -0
  589. package/widgets/bento-grid/templates/wrapper.php +72 -0
  590. package/widgets/bento-portfolio/bento-portfolio.php +399 -0
  591. package/widgets/bento-portfolio/data/view.php +124 -0
  592. package/widgets/bento-portfolio/templates/partials/portfolio-card.php +84 -0
  593. package/widgets/bento-portfolio/templates/partials/portfolio-default-grid.php +35 -0
  594. package/widgets/bento-portfolio/templates/partials/portfolio-two-column-second-row-grid.php +39 -0
  595. package/widgets/bento-portfolio/templates/partials/portfolio-two-row-grid.php +35 -0
  596. package/widgets/bento-portfolio/templates/wrapper.php +88 -0
  597. package/widgets/blog-grid/blog-grid.php +359 -0
  598. package/widgets/blog-grid/data/view.php +209 -0
  599. package/widgets/blog-grid/templates/partials/card.php +73 -0
  600. package/widgets/blog-grid/templates/wrapper.php +89 -0
  601. package/widgets/card-hover-reveal/card-hover-reveal.php +329 -0
  602. package/widgets/card-hover-reveal/data/view.php +141 -0
  603. package/widgets/card-hover-reveal/templates/partials/card.php +119 -0
  604. package/widgets/card-hover-reveal/templates/wrapper.php +80 -0
  605. package/widgets/client-logos/client-logos.php +214 -0
  606. package/widgets/client-logos/data/view.php +105 -0
  607. package/widgets/client-logos/templates/partials/client-item.php +38 -0
  608. package/widgets/client-logos/templates/wrapper.php +62 -0
  609. package/widgets/content-block/content-block.php +280 -0
  610. package/widgets/content-block/data/view.php +120 -0
  611. package/widgets/content-block/templates/partials/content.php +52 -0
  612. package/widgets/content-block/templates/wrapper.php +73 -0
  613. package/widgets/cta-banner/cta-banner.php +300 -0
  614. package/widgets/cta-banner/data/view.php +101 -0
  615. package/widgets/cta-banner/templates/wrapper.php +131 -0
  616. package/widgets/cta-notify/cta-notify.php +135 -0
  617. package/widgets/cta-notify/data/view.php +55 -0
  618. package/widgets/cta-notify/templates/wrapper.php +69 -0
  619. package/widgets/cta-split/cta-split.php +246 -0
  620. package/widgets/cta-split/data/view.php +86 -0
  621. package/widgets/cta-split/templates/wrapper.php +113 -0
  622. package/widgets/faq/data/view.php +105 -0
  623. package/widgets/faq/faq.php +253 -0
  624. package/widgets/faq/templates/partials/accordion.php +74 -0
  625. package/widgets/faq/templates/partials/layout-centered.php +41 -0
  626. package/widgets/faq/templates/partials/layout-split.php +47 -0
  627. package/widgets/faq/templates/partials/layout-stacked.php +57 -0
  628. package/widgets/faq/templates/wrapper.php +76 -0
  629. package/widgets/feature-grid/data/view.php +121 -0
  630. package/widgets/feature-grid/feature-grid.php +321 -0
  631. package/widgets/feature-grid/templates/partials/centered-2x2.php +69 -0
  632. package/widgets/feature-grid/templates/partials/feature-item.php +54 -0
  633. package/widgets/feature-grid/templates/wrapper.php +71 -0
  634. package/widgets/feature-list/data/view.php +56 -0
  635. package/widgets/feature-list/feature-list.php +160 -0
  636. package/widgets/feature-list/templates/wrapper.php +69 -0
  637. package/widgets/feature-list-cta/data/view.php +85 -0
  638. package/widgets/feature-list-cta/feature-list-cta.php +226 -0
  639. package/widgets/feature-list-cta/templates/partials/feature-item.php +49 -0
  640. package/widgets/feature-list-cta/templates/wrapper.php +65 -0
  641. package/widgets/footer/data/view.php +139 -0
  642. package/widgets/footer/footer.php +389 -0
  643. package/widgets/footer/templates/partials/bottom.php +77 -0
  644. package/widgets/footer/templates/partials/cta.php +47 -0
  645. package/widgets/footer/templates/partials/link-columns.php +52 -0
  646. package/widgets/footer/templates/wrapper.php +53 -0
  647. package/widgets/footer-brand/data/view.php +135 -0
  648. package/widgets/footer-brand/footer-brand.php +278 -0
  649. package/widgets/footer-brand/templates/partials/brand.php +69 -0
  650. package/widgets/footer-brand/templates/partials/link-columns.php +51 -0
  651. package/widgets/footer-brand/templates/wrapper.php +59 -0
  652. package/widgets/footer-links-contact/data/view.php +165 -0
  653. package/widgets/footer-links-contact/footer-links-contact.php +361 -0
  654. package/widgets/footer-links-contact/templates/partials/bottom.php +70 -0
  655. package/widgets/footer-links-contact/templates/partials/contact-column.php +66 -0
  656. package/widgets/footer-links-contact/templates/partials/link-column.php +39 -0
  657. package/widgets/footer-links-contact/templates/partials/logo-column.php +46 -0
  658. package/widgets/footer-links-contact/templates/wrapper.php +68 -0
  659. package/widgets/form-contact/data/view.php +133 -0
  660. package/widgets/form-contact/form-contact.php +274 -0
  661. package/widgets/form-contact/templates/partials/testimonial.php +83 -0
  662. package/widgets/form-contact/templates/wrapper.php +98 -0
  663. package/widgets/grid-case-studies/data/view.php +88 -0
  664. package/widgets/grid-case-studies/grid-case-studies.php +262 -0
  665. package/widgets/grid-case-studies/templates/partials/card.php +66 -0
  666. package/widgets/grid-case-studies/templates/wrapper.php +69 -0
  667. package/widgets/grid-components/data/view.php +131 -0
  668. package/widgets/grid-components/grid-components.php +316 -0
  669. package/widgets/grid-components/templates/partials/component-card.php +81 -0
  670. package/widgets/grid-components/templates/wrapper.php +55 -0
  671. package/widgets/grid-posts/data/view.php +159 -0
  672. package/widgets/grid-posts/grid-posts.php +295 -0
  673. package/widgets/grid-posts/templates/partials/card-overlay.php +58 -0
  674. package/widgets/grid-posts/templates/partials/card.php +49 -0
  675. package/widgets/grid-posts/templates/wrapper.php +59 -0
  676. package/widgets/grid-team/data/view.php +80 -0
  677. package/widgets/grid-team/grid-team.php +201 -0
  678. package/widgets/grid-team/templates/partials/team-card.php +52 -0
  679. package/widgets/grid-team/templates/wrapper.php +67 -0
  680. package/widgets/grid-testimonials/data/view.php +179 -0
  681. package/widgets/grid-testimonials/grid-testimonials.php +370 -0
  682. package/widgets/grid-testimonials/templates/partials/layout-bento.php +36 -0
  683. package/widgets/grid-testimonials/templates/partials/layout-masonry.php +74 -0
  684. package/widgets/grid-testimonials/templates/partials/testimonial-card.php +85 -0
  685. package/widgets/grid-testimonials/templates/wrapper.php +84 -0
  686. package/widgets/hero-announcement/data/view.php +98 -0
  687. package/widgets/hero-announcement/hero-announcement.php +270 -0
  688. package/widgets/hero-announcement/templates/wrapper.php +111 -0
  689. package/widgets/hero-centered-image/data/view.php +128 -0
  690. package/widgets/hero-centered-image/hero-centered-image.php +297 -0
  691. package/widgets/hero-centered-image/templates/wrapper.php +123 -0
  692. package/widgets/hero-collage/data/view.php +113 -0
  693. package/widgets/hero-collage/hero-collage.php +151 -0
  694. package/widgets/hero-collage/templates/wrapper.php +102 -0
  695. package/widgets/hero-overlay/data/view.php +121 -0
  696. package/widgets/hero-overlay/hero-overlay.php +277 -0
  697. package/widgets/hero-overlay/templates/wrapper.php +225 -0
  698. package/widgets/hero-saas/data/view.php +106 -0
  699. package/widgets/hero-saas/hero-saas.php +175 -0
  700. package/widgets/hero-saas/templates/partials/layout-centered.php +70 -0
  701. package/widgets/hero-saas/templates/partials/layout-split.php +76 -0
  702. package/widgets/hero-saas/templates/partials/layout-stacked.php +70 -0
  703. package/widgets/hero-saas/templates/wrapper.php +54 -0
  704. package/widgets/hero-split/data/view.php +92 -0
  705. package/widgets/hero-split/hero-split.php +127 -0
  706. package/widgets/hero-split/templates/wrapper.php +86 -0
  707. package/widgets/hero-stacked-image/data/view.php +142 -0
  708. package/widgets/hero-stacked-image/hero-stacked-image.php +248 -0
  709. package/widgets/hero-stacked-image/templates/wrapper.php +176 -0
  710. package/widgets/intro-pattern/data/view.php +73 -0
  711. package/widgets/intro-pattern/intro-pattern.php +161 -0
  712. package/widgets/intro-pattern/templates/wrapper.php +61 -0
  713. package/widgets/intro-text/data/view.php +97 -0
  714. package/widgets/intro-text/intro-text.php +252 -0
  715. package/widgets/intro-text/templates/wrapper.php +75 -0
  716. package/widgets/logo-grid/data/view.php +113 -0
  717. package/widgets/logo-grid/logo-grid.php +281 -0
  718. package/widgets/logo-grid/templates/wrapper.php +213 -0
  719. package/widgets/newsletter/data/view.php +75 -0
  720. package/widgets/newsletter/newsletter.php +210 -0
  721. package/widgets/newsletter/templates/wrapper.php +137 -0
  722. package/widgets/outreach-dashboard/data/view.php +176 -0
  723. package/widgets/outreach-dashboard/outreach-dashboard.php +504 -0
  724. package/widgets/outreach-dashboard/templates/partials/card-chat.php +69 -0
  725. package/widgets/outreach-dashboard/templates/partials/card-engagement.php +60 -0
  726. package/widgets/outreach-dashboard/templates/partials/card-integrations.php +39 -0
  727. package/widgets/outreach-dashboard/templates/partials/card-meetings.php +43 -0
  728. package/widgets/outreach-dashboard/templates/partials/card-networking.php +28 -0
  729. package/widgets/outreach-dashboard/templates/wrapper.php +76 -0
  730. package/widgets/pipeline-dashboard/data/view.php +131 -0
  731. package/widgets/pipeline-dashboard/pipeline-dashboard.php +407 -0
  732. package/widgets/pipeline-dashboard/templates/partials/app-bar.php +31 -0
  733. package/widgets/pipeline-dashboard/templates/partials/kanban.php +56 -0
  734. package/widgets/pipeline-dashboard/templates/partials/pipeline-header.php +66 -0
  735. package/widgets/pipeline-dashboard/templates/wrapper.php +64 -0
  736. package/widgets/pricing-table/data/view.php +133 -0
  737. package/widgets/pricing-table/pricing-table.php +376 -0
  738. package/widgets/pricing-table/templates/partials/pricing-card.php +125 -0
  739. package/widgets/pricing-table/templates/wrapper.php +164 -0
  740. package/widgets/sales-dashboard/data/view.php +158 -0
  741. package/widgets/sales-dashboard/sales-dashboard.php +434 -0
  742. package/widgets/sales-dashboard/templates/partials/card-competitors.php +78 -0
  743. package/widgets/sales-dashboard/templates/partials/card-feature.php +58 -0
  744. package/widgets/sales-dashboard/templates/partials/card-profile.php +76 -0
  745. package/widgets/sales-dashboard/templates/wrapper.php +74 -0
  746. package/widgets/section-stats/data/view.php +105 -0
  747. package/widgets/section-stats/section-stats.php +232 -0
  748. package/widgets/section-stats/templates/partials/stat-card.php +44 -0
  749. package/widgets/section-stats/templates/wrapper.php +87 -0
  750. package/widgets/services/data/view.php +91 -0
  751. package/widgets/services/services.php +198 -0
  752. package/widgets/services/templates/partials/service-item.php +35 -0
  753. package/widgets/services/templates/wrapper.php +92 -0
  754. package/widgets/simple-page-hero/data/view.php +52 -0
  755. package/widgets/simple-page-hero/simple-page-hero.php +147 -0
  756. package/widgets/simple-page-hero/templates/wrapper.php +54 -0
  757. package/widgets/social-proof/data/view.php +143 -0
  758. package/widgets/social-proof/social-proof.php +389 -0
  759. package/widgets/social-proof/templates/partials/layout-trust.php +73 -0
  760. package/widgets/social-proof/templates/partials/stat-card.php +32 -0
  761. package/widgets/social-proof/templates/partials/stat-item.php +35 -0
  762. package/widgets/social-proof/templates/wrapper.php +93 -0
  763. package/widgets/testimonial-quote/data/view.php +62 -0
  764. package/widgets/testimonial-quote/templates/wrapper.php +66 -0
  765. package/widgets/testimonial-quote/testimonial-quote.php +157 -0
  766. package/widgets.json +75 -0
  767. package/widgets.json.minimal +17 -0
@@ -0,0 +1,630 @@
1
+ <?php
2
+ /**
3
+ * Template: Widget Filter Wrapper
4
+ *
5
+ * Displays a grid of available widgets with category filtering sidebar.
6
+ *
7
+ * AVAILABLE DATA ($view):
8
+ * - headline, headline_tag, show_search, show_categories
9
+ * - categories (array with label, icon, count)
10
+ * - widgets (array with name, display, category)
11
+ * - grid_class, classes, widget_id, animation
12
+ *
13
+ * @package SocialLane_Elements
14
+ */
15
+
16
+ if ( ! defined( 'ABSPATH' ) ) {
17
+ exit;
18
+ }
19
+
20
+ if ( empty( $view ) ) {
21
+ return;
22
+ }
23
+
24
+ $anim = $view['animation'] ?? [];
25
+ $section_attrs = sociallane_section_animation_attrs( $anim );
26
+ $stagger_attrs = sociallane_stagger_attrs( $anim );
27
+ $block_id = 'widget-filter-' . $view['widget_id'];
28
+ $categories = $view['categories'];
29
+ $categories_visible = $view['categories_visible'] ?? $categories;
30
+ $categories_more = $view['categories_more'] ?? [];
31
+ $has_more_categories = ! empty( $view['has_more_categories'] ) && ! empty( $categories_more );
32
+ $widgets = $view['widgets'];
33
+ $classes = is_array( $view['classes'] ?? null ) ? $view['classes'] : [];
34
+
35
+ // Prepare class arrays for JavaScript (split by space for classList compatibility)
36
+ $filter_active_classes = ! empty( $classes['filter_active'] ) ? explode( ' ', $classes['filter_active'] ) : [];
37
+ $filter_inactive_classes = ! empty( $classes['filter_inactive'] ) ? explode( ' ', $classes['filter_inactive'] ) : [];
38
+ ?>
39
+ <script>
40
+ (function() {
41
+ document.addEventListener('DOMContentLoaded', function() {
42
+ var block = document.getElementById('<?php echo esc_js( $block_id ); ?>');
43
+ if (!block) return;
44
+ var filterBtns = block.querySelectorAll('[data-filter]');
45
+ var cards = block.querySelectorAll('[data-category]');
46
+ var search = block.querySelector('[data-search]');
47
+ var countEl = block.querySelector('[data-count-display]');
48
+ var activeClasses = <?php echo json_encode( $filter_active_classes ); ?>;
49
+ var inactiveClasses = <?php echo json_encode( $filter_inactive_classes ); ?>;
50
+
51
+ function addClasses(el, arr) { arr.forEach(function(c) { if (c) el.classList.add(c); }); }
52
+ function removeClasses(el, arr) { arr.forEach(function(c) { if (c) el.classList.remove(c); }); }
53
+ function updateCount() {
54
+ var n = 0;
55
+ cards.forEach(function(c) { if (c.style.display !== 'none') n++; });
56
+ if (countEl) countEl.textContent = n;
57
+ }
58
+
59
+ function copyToClipboard(text, btn) {
60
+ var span = btn && btn.querySelector('[data-copy-label]');
61
+ var orig = span ? span.textContent : (btn ? btn.textContent : '');
62
+ function showDone() {
63
+ if (span) span.textContent = '<?php echo esc_js( __( 'Copied!', 'sociallane-elements' ) ); ?>';
64
+ else if (btn) btn.textContent = '<?php echo esc_js( __( 'Copied!', 'sociallane-elements' ) ); ?>';
65
+ setTimeout(function() {
66
+ if (span) span.textContent = orig;
67
+ else if (btn) btn.textContent = orig;
68
+ }, 1500);
69
+ }
70
+ if (navigator.clipboard && navigator.clipboard.writeText) {
71
+ navigator.clipboard.writeText(text).then(showDone).catch(function() {
72
+ fallbackCopy(text);
73
+ showDone();
74
+ });
75
+ } else {
76
+ fallbackCopy(text);
77
+ showDone();
78
+ }
79
+ }
80
+ function fallbackCopy(text) {
81
+ var ta = document.createElement('textarea');
82
+ ta.value = text;
83
+ ta.style.position = 'fixed';
84
+ ta.style.left = '-9999px';
85
+ ta.style.top = '0';
86
+ document.body.appendChild(ta);
87
+ ta.focus();
88
+ ta.select();
89
+ try { document.execCommand('copy'); } catch (e) {}
90
+ document.body.removeChild(ta);
91
+ }
92
+
93
+ function applyActiveToFilterBtn(activeBtn) {
94
+ filterBtns.forEach(function(b) {
95
+ removeClasses(b, activeClasses);
96
+ addClasses(b, inactiveClasses);
97
+ });
98
+ if (activeBtn) {
99
+ removeClasses(activeBtn, inactiveClasses);
100
+ addClasses(activeBtn, activeClasses);
101
+ }
102
+ }
103
+
104
+ filterBtns.forEach(function(btn) {
105
+ btn.addEventListener('click', function() {
106
+ var filter = this.getAttribute('data-filter');
107
+ applyActiveToFilterBtn(this);
108
+ cards.forEach(function(c) {
109
+ var show = filter === 'all' || c.getAttribute('data-category') === filter;
110
+ c.style.display = show ? '' : 'none';
111
+ });
112
+ updateCount();
113
+ });
114
+ });
115
+
116
+ // Show more / Show less categories
117
+ var showMoreBtn = block.querySelector('[data-filter-show-more]');
118
+ var moreList = block.querySelector('[data-filter-more-list]');
119
+ var showMoreLabel = block.querySelector('[data-filter-show-more-label]');
120
+ var showMoreIcon = block.querySelector('[data-filter-show-more-icon]');
121
+ if (showMoreBtn && moreList && showMoreLabel) {
122
+ showMoreBtn.addEventListener('click', function() {
123
+ var expanded = this.getAttribute('aria-expanded') === 'true';
124
+ this.setAttribute('aria-expanded', !expanded);
125
+ moreList.classList.toggle('hidden', expanded);
126
+ moreList.setAttribute('aria-hidden', expanded ? 'true' : 'false');
127
+ showMoreLabel.textContent = expanded ? '<?php echo esc_js( __( 'Show more', 'sociallane-elements' ) ); ?>' : '<?php echo esc_js( __( 'Show less', 'sociallane-elements' ) ); ?>';
128
+ if (showMoreIcon) showMoreIcon.style.transform = expanded ? '' : 'rotate(180deg)';
129
+ });
130
+ }
131
+
132
+ if (search) {
133
+ search.addEventListener('input', function() {
134
+ var q = this.value.toLowerCase().trim();
135
+ cards.forEach(function(c) {
136
+ var show = !q || (c.getAttribute('data-display') || '').toLowerCase().indexOf(q) !== -1 ||
137
+ (c.getAttribute('data-name') || '').toLowerCase().indexOf(q) !== -1 ||
138
+ (c.getAttribute('data-category') || '').toLowerCase().indexOf(q) !== -1;
139
+ c.style.display = show ? '' : 'none';
140
+ });
141
+ updateCount();
142
+ });
143
+ }
144
+
145
+ block.querySelectorAll('[data-copy]').forEach(function(btn) {
146
+ btn.addEventListener('click', function(e) {
147
+ e.preventDefault();
148
+ e.stopPropagation();
149
+ var name = this.getAttribute('data-copy');
150
+ if (name) copyToClipboard(name, this);
151
+ });
152
+ });
153
+
154
+ block.querySelectorAll('[data-copy-npm]').forEach(function(btn) {
155
+ btn.addEventListener('click', function(e) {
156
+ e.preventDefault();
157
+ e.stopPropagation();
158
+ var cmd = btn.getAttribute('data-npm-command') || '';
159
+ if (cmd) copyToClipboard(cmd, this);
160
+ });
161
+ });
162
+
163
+ var collection = [];
164
+ var collectionList = block.querySelector('[data-collection-list]');
165
+ var collectionActions = block.querySelector('[data-collection-actions]');
166
+ var copyCollectionBtn = block.querySelector('[data-copy-collection-npm]');
167
+ var clearCollectionBtn = block.querySelector('[data-clear-collection]');
168
+
169
+ function renderCollection() {
170
+ if (!collectionList) return;
171
+ collectionList.innerHTML = '';
172
+ if (collection.length) {
173
+ collection.forEach(function(item) {
174
+ var div = document.createElement('div');
175
+ div.className = 'truncate';
176
+ div.textContent = item.display;
177
+ collectionList.appendChild(div);
178
+ });
179
+ } else {
180
+ var empty = document.createElement('span');
181
+ empty.className = 'opacity-60';
182
+ empty.textContent = '<?php echo esc_js( __( 'No widgets added yet.', 'sociallane-elements' ) ); ?>';
183
+ collectionList.appendChild(empty);
184
+ }
185
+ if (collectionActions) collectionActions.classList.toggle('hidden', collection.length === 0);
186
+ }
187
+
188
+ function syncCheckboxes() {
189
+ block.querySelectorAll('[data-add-to-collection]').forEach(function(cb) {
190
+ var pkg = cb.getAttribute('data-npm-package');
191
+ cb.checked = collection.some(function(item) { return item.package === pkg; });
192
+ });
193
+ }
194
+
195
+ block.querySelectorAll('[data-add-to-collection]').forEach(function(cb) {
196
+ cb.addEventListener('change', function() {
197
+ var pkg = cb.getAttribute('data-npm-package');
198
+ var display = cb.getAttribute('data-display') || pkg;
199
+ if (cb.checked) {
200
+ if (!collection.some(function(item) { return item.package === pkg; })) {
201
+ collection.push({ package: pkg, display: display });
202
+ }
203
+ } else {
204
+ collection = collection.filter(function(item) { return item.package !== pkg; });
205
+ }
206
+ renderCollection();
207
+ });
208
+ });
209
+
210
+ if (copyCollectionBtn) {
211
+ copyCollectionBtn.addEventListener('click', function() {
212
+ if (collection.length === 0) return;
213
+ var cmd = 'npm install ' + collection.map(function(item) { return item.package; }).join(' ');
214
+ copyToClipboard(cmd, copyCollectionBtn);
215
+ });
216
+ }
217
+
218
+ if (clearCollectionBtn) {
219
+ clearCollectionBtn.addEventListener('click', function() {
220
+ collection = [];
221
+ renderCollection();
222
+ syncCheckboxes();
223
+ });
224
+ }
225
+
226
+ renderCollection();
227
+ updateCount();
228
+
229
+ // Hover preview: show iframe on card hover, keep detail page link
230
+ var hoverPreview = block.querySelector('[data-hover-preview]');
231
+ var hoverIframe = block.querySelector('[data-hover-preview-iframe]');
232
+ var previewCards = block.querySelectorAll('.widget-filter__card[data-preview-embed-url]');
233
+ var hoverShowTimer = null;
234
+ var hoverHideTimer = null;
235
+ var PREVIEW_HOVER_DELAY = 350;
236
+ var PREVIEW_HIDE_DELAY = 200;
237
+
238
+ function clearPreviewTimers() {
239
+ if (hoverShowTimer) { clearTimeout(hoverShowTimer); hoverShowTimer = null; }
240
+ if (hoverHideTimer) { clearTimeout(hoverHideTimer); hoverHideTimer = null; }
241
+ }
242
+
243
+ function positionPreviewPanel(card) {
244
+ if (!hoverPreview || !card) return;
245
+ var cr = card.getBoundingClientRect();
246
+ var pw = 420;
247
+ var ph = 280;
248
+ var gap = 8;
249
+ var viewW = window.innerWidth;
250
+ var viewH = window.innerHeight;
251
+ var top = 0;
252
+ var left = cr.left + (cr.width / 2) - (pw / 2);
253
+ left = Math.max(12, Math.min(left, viewW - pw - 12));
254
+ if (cr.top >= ph + gap + 60) {
255
+ top = cr.top - ph - gap;
256
+ } else if (viewH - cr.bottom >= ph + gap) {
257
+ top = cr.bottom + gap;
258
+ } else {
259
+ top = Math.max(12, cr.top + (cr.height / 2) - (ph / 2));
260
+ }
261
+ hoverPreview.style.left = left + 'px';
262
+ hoverPreview.style.top = top + 'px';
263
+ }
264
+
265
+ function showHoverPreview(url, label) {
266
+ clearPreviewTimers();
267
+ if (!hoverPreview || !hoverIframe) return;
268
+ hoverIframe.src = url;
269
+ hoverIframe.title = label || 'Preview';
270
+ hoverPreview.classList.remove('invisible', 'opacity-0', 'pointer-events-none');
271
+ hoverPreview.classList.add('pointer-events-auto');
272
+ hoverPreview.setAttribute('aria-hidden', 'false');
273
+ }
274
+
275
+ function hideHoverPreview() {
276
+ clearPreviewTimers();
277
+ hoverHideTimer = setTimeout(function() {
278
+ hoverHideTimer = null;
279
+ if (!hoverPreview || !hoverIframe) return;
280
+ hoverPreview.classList.add('invisible', 'opacity-0', 'pointer-events-none');
281
+ hoverPreview.classList.remove('pointer-events-auto');
282
+ hoverPreview.setAttribute('aria-hidden', 'true');
283
+ hoverIframe.src = 'about:blank';
284
+ }, PREVIEW_HIDE_DELAY);
285
+ }
286
+
287
+ if (hoverPreview && hoverIframe && previewCards.length) {
288
+ previewCards.forEach(function(card) {
289
+ var url = card.getAttribute('data-preview-embed-url');
290
+ var label = card.getAttribute('data-display') || '';
291
+ if (!url) return;
292
+
293
+ card.addEventListener('mouseenter', function() {
294
+ clearPreviewTimers();
295
+ hoverShowTimer = setTimeout(function() {
296
+ hoverShowTimer = null;
297
+ positionPreviewPanel(card);
298
+ showHoverPreview(url, label);
299
+ }, PREVIEW_HOVER_DELAY);
300
+ });
301
+
302
+ card.addEventListener('mouseleave', function() {
303
+ clearPreviewTimers();
304
+ hoverHideTimer = setTimeout(hideHoverPreview, PREVIEW_HIDE_DELAY);
305
+ });
306
+ });
307
+
308
+ hoverPreview.addEventListener('mouseenter', function() {
309
+ clearPreviewTimers();
310
+ });
311
+ hoverPreview.addEventListener('mouseleave', function() {
312
+ hideHoverPreview();
313
+ });
314
+ }
315
+ });
316
+ })();
317
+ </script>
318
+ <?php // ========== WIDGET FILTER START ========== ?>
319
+
320
+ <section
321
+ id="<?php echo esc_attr( $block_id ); ?>"
322
+ class="widget-filter w-full <?php echo esc_attr( $classes['section'] ?? '' ); ?> py-12 md:py-16 lg:py-20 relative"
323
+ <?php echo $section_attrs ? ' ' . $section_attrs : ''; ?>
324
+ aria-label="<?php esc_attr_e( 'Widget Catalog', 'sociallane-elements' ); ?>"
325
+ >
326
+ <div class="container mx-auto px-4 sm:px-6 lg:px-8">
327
+ <?php // Header ?>
328
+ <header class="mb-8">
329
+ <<?php echo $view['headline_tag']; ?>
330
+ class="<?php echo esc_attr( $classes['headline'] ?? '' ); ?> text-2xl md:text-3xl lg:text-4xl font-bold font-heading leading-tight"
331
+ >
332
+ <?php echo $view['headline']; ?>
333
+ </<?php echo $view['headline_tag']; ?>>
334
+ </header>
335
+
336
+ <?php // Main Layout: Sidebar (Left) + Grid (Right) ?>
337
+ <div class="flex flex-col lg:flex-row gap-8">
338
+ <?php // Sidebar Filters (Left) - sticky so filter stays visible when scrolling ?>
339
+ <aside class="w-full lg:w-64 shrink-0 order-1">
340
+ <div class="sticky top-4 z-10 <?php echo esc_attr( $classes['filter_bg'] ?? '' ); ?> rounded-xl p-5 shadow-sm border border-neutral-200/50 dark:border-neutral-700/50">
341
+ <h3 class="<?php echo esc_attr( $classes['headline'] ?? '' ); ?> font-semibold font-heading mb-4 text-base">
342
+ <?php esc_html_e( 'Filter Widgets', 'sociallane-elements' ); ?>
343
+ </h3>
344
+
345
+ <?php // Search Input (Desktop - in sidebar) ?>
346
+ <?php if ( $view['show_search'] ) : ?>
347
+ <div class="relative mb-4">
348
+ <input
349
+ type="text"
350
+ data-search
351
+ placeholder="<?php esc_attr_e( 'Search...', 'sociallane-elements' ); ?>"
352
+ class="w-full px-3 py-2 rounded-lg border text-sm <?php echo esc_attr( $classes['search_bg'] ?? '' ); ?> <?php echo esc_attr( $classes['search_text'] ?? '' ); ?> focus:outline-none focus:ring-2 focus:ring-primary transition-colors"
353
+ />
354
+ <svg
355
+ class="absolute right-2.5 top-1/2 -translate-y-1/2 w-4 h-4 <?php echo esc_attr( $classes['subtext'] ?? '' ); ?>"
356
+ fill="none"
357
+ stroke="currentColor"
358
+ viewBox="0 0 24 24"
359
+ aria-hidden="true"
360
+ >
361
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
362
+ </svg>
363
+ </div>
364
+ <?php endif; ?>
365
+
366
+ <?php // Category Filter List: first 8 visible, rest behind "Show more" ?>
367
+ <?php if ( $view['show_categories'] && ! empty( $categories ) ) : ?>
368
+ <nav
369
+ role="navigation"
370
+ aria-label="<?php esc_attr_e( 'Filter widgets by category', 'sociallane-elements' ); ?>"
371
+ >
372
+ <ul class="space-y-1">
373
+ <?php foreach ( $categories_visible as $key => $cat ) : ?>
374
+ <?php
375
+ $is_active = $key === 'all';
376
+ $btn_class = $is_active
377
+ ? ( $classes['filter_active'] ?? '' )
378
+ : ( $classes['filter_inactive'] ?? '' );
379
+ ?>
380
+ <li>
381
+ <button
382
+ type="button"
383
+ data-filter="<?php echo esc_attr( $key ); ?>"
384
+ class="w-full text-left inline-flex items-center justify-between gap-2 px-3 py-2 rounded-lg text-sm font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2 <?php echo esc_attr( $btn_class ); ?>"
385
+ >
386
+ <span class="flex items-center gap-2">
387
+ <?php if ( ! empty( $cat['icon'] ) ) : ?>
388
+ <i class="<?php echo esc_attr( $cat['icon'] ); ?> text-base" aria-hidden="true"></i>
389
+ <?php endif; ?>
390
+ <span><?php echo esc_html( $cat['label'] ); ?></span>
391
+ </span>
392
+ <?php if ( isset( $cat['count'] ) && $cat['count'] > 0 ) : ?>
393
+ <span class="<?php echo esc_attr( $classes['subtext'] ?? '' ); ?> text-xs">
394
+ <?php echo esc_html( (string) $cat['count'] ); ?>
395
+ </span>
396
+ <?php endif; ?>
397
+ </button>
398
+ </li>
399
+ <?php endforeach; ?>
400
+ </ul>
401
+ <?php if ( $has_more_categories ) : ?>
402
+ <div data-filter-more-wrap class="mt-2">
403
+ <button
404
+ type="button"
405
+ data-filter-show-more
406
+ class="w-full text-left inline-flex items-center gap-2 px-3 py-2 rounded-lg text-sm font-medium <?php echo esc_attr( $classes['filter_inactive'] ?? '' ); ?> hover:bg-neutral-200 dark:hover:bg-neutral-700 transition-colors focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2"
407
+ aria-expanded="false"
408
+ aria-controls="<?php echo esc_attr( $block_id ); ?>-more-categories"
409
+ >
410
+ <svg data-filter-show-more-icon class="w-4 h-4 transition-transform" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
411
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7" />
412
+ </svg>
413
+ <span data-filter-show-more-label><?php esc_html_e( 'Show more', 'sociallane-elements' ); ?></span>
414
+ </button>
415
+ <ul id="<?php echo esc_attr( $block_id ); ?>-more-categories" data-filter-more-list class="space-y-1 mt-1 hidden" aria-hidden="true">
416
+ <?php foreach ( $categories_more as $key => $cat ) : ?>
417
+ <?php
418
+ $btn_class = $classes['filter_inactive'] ?? '';
419
+ ?>
420
+ <li>
421
+ <button
422
+ type="button"
423
+ data-filter="<?php echo esc_attr( $key ); ?>"
424
+ class="w-full text-left inline-flex items-center justify-between gap-2 px-3 py-2 rounded-lg text-sm font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2 <?php echo esc_attr( $btn_class ); ?>"
425
+ >
426
+ <span class="flex items-center gap-2">
427
+ <?php if ( ! empty( $cat['icon'] ) ) : ?>
428
+ <i class="<?php echo esc_attr( $cat['icon'] ); ?> text-base" aria-hidden="true"></i>
429
+ <?php endif; ?>
430
+ <span><?php echo esc_html( $cat['label'] ); ?></span>
431
+ </span>
432
+ <?php if ( isset( $cat['count'] ) && $cat['count'] > 0 ) : ?>
433
+ <span class="<?php echo esc_attr( $classes['subtext'] ?? '' ); ?> text-xs">
434
+ <?php echo esc_html( (string) $cat['count'] ); ?>
435
+ </span>
436
+ <?php endif; ?>
437
+ </button>
438
+ </li>
439
+ <?php endforeach; ?>
440
+ </ul>
441
+ </div>
442
+ <?php endif; ?>
443
+ </nav>
444
+ <?php endif; ?>
445
+
446
+ <?php // My collection: selected widgets, copy npm install for all ?>
447
+ <div id="<?php echo esc_attr( $block_id ); ?>-collection" class="mt-6 pt-6 border-t border-neutral-200 dark:border-neutral-700" data-collection-panel>
448
+ <h3 class="<?php echo esc_attr( $classes['headline'] ?? '' ); ?> font-semibold font-heading mb-3 text-sm">
449
+ <?php esc_html_e( 'My collection', 'sociallane-elements' ); ?>
450
+ </h3>
451
+ <p class="<?php echo esc_attr( $classes['subtext'] ?? '' ); ?> text-xs mb-3">
452
+ <?php esc_html_e( 'Add widgets below, then copy one command to install them all.', 'sociallane-elements' ); ?>
453
+ </p>
454
+ <div data-collection-list class="min-h-[2rem] text-xs <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> mb-3 space-y-1 max-h-40 overflow-auto"></div>
455
+ <div data-collection-actions class="flex flex-col gap-2 hidden">
456
+ <button type="button" data-copy-collection-npm class="w-full inline-flex items-center justify-center gap-2 px-3 py-2 rounded-lg text-sm font-medium bg-primary text-white dark:bg-neutral-900 hover:opacity-90 focus:outline-none focus:ring-2 focus:ring-primary focus:ring-offset-2">
457
+ <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z" /></svg>
458
+ <span data-copy-label><?php esc_html_e( 'Copy npm install', 'sociallane-elements' ); ?></span>
459
+ </button>
460
+ <button type="button" data-clear-collection class="text-xs <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> hover:underline focus:outline-none text-left">
461
+ <?php esc_html_e( 'Clear collection', 'sociallane-elements' ); ?>
462
+ </button>
463
+ </div>
464
+ </div>
465
+ </div>
466
+ </aside>
467
+
468
+ <?php // Widget Cards Grid (Main Content - Right) ?>
469
+ <main class="flex-1 order-2">
470
+ <?php // Search Input (Mobile/Tablet - above grid) ?>
471
+ <?php if ( $view['show_search'] ) : ?>
472
+ <div class="relative mb-6 lg:hidden">
473
+ <input
474
+ type="text"
475
+ data-search
476
+ placeholder="<?php esc_attr_e( 'Search widgets...', 'sociallane-elements' ); ?>"
477
+ class="w-full px-4 py-3 rounded-lg border <?php echo esc_attr( $classes['search_bg'] ?? '' ); ?> <?php echo esc_attr( $classes['search_text'] ?? '' ); ?> focus:outline-none focus:ring-2 focus:ring-primary transition-colors"
478
+ />
479
+ <svg
480
+ class="absolute right-3 top-1/2 -translate-y-1/2 w-5 h-5 <?php echo esc_attr( $classes['subtext'] ?? '' ); ?>"
481
+ fill="none"
482
+ stroke="currentColor"
483
+ viewBox="0 0 24 24"
484
+ aria-hidden="true"
485
+ >
486
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
487
+ </svg>
488
+ </div>
489
+ <?php endif; ?>
490
+
491
+ <?php // Results Count ?>
492
+ <p class="<?php echo esc_attr( $classes['subtext'] ?? '' ); ?> mb-4 text-sm">
493
+ <span data-count-display><?php echo count( $widgets ); ?></span> <?php esc_html_e( 'widgets found', 'sociallane-elements' ); ?>
494
+ </p>
495
+
496
+ <?php // Widget Cards Grid ?>
497
+ <?php if ( ! empty( $widgets ) ) : ?>
498
+ <div
499
+ class="grid <?php echo esc_attr( $view['grid_class'] ); ?> gap-4 sm:gap-6"
500
+ <?php echo $stagger_attrs ? ' ' . $stagger_attrs : ''; ?>
501
+ role="list"
502
+ aria-label="<?php esc_attr_e( 'Available widgets', 'sociallane-elements' ); ?>"
503
+ >
504
+ <?php foreach ( $widgets as $widget ) : ?>
505
+ <?php
506
+ $cat_label = $categories[ $widget['category'] ]['label'] ?? $widget['category'];
507
+ $npm_cmd = isset( $widget['npm_command'] ) && $widget['npm_command'] !== '' ? $widget['npm_command'] : 'npm install @sociallane/widget-' . $widget['name'];
508
+ $npm_pkg = isset( $widget['npm_package'] ) && $widget['npm_package'] !== '' ? $widget['npm_package'] : '@sociallane/widget-' . $widget['name'];
509
+ ?>
510
+ <?php
511
+ $preview_embed_url = ! empty( $view['preview_pages_enabled'] )
512
+ ? add_query_arg( 'embed', '1', home_url( '/widget-preview/' . $widget['name'] . '/' ) )
513
+ : '';
514
+ ?>
515
+ <article
516
+ data-category="<?php echo esc_attr( $widget['category'] ); ?>"
517
+ data-widget-name="<?php echo esc_attr( $widget['name'] ); ?>"
518
+ data-display="<?php echo esc_attr( $widget['display'] ); ?>"
519
+ <?php if ( $preview_embed_url !== '' ) : ?>
520
+ data-preview-embed-url="<?php echo esc_url( $preview_embed_url ); ?>"
521
+ <?php endif; ?>
522
+ class="widget-filter__card bg-white dark:bg-neutral-800 rounded-xl border border-neutral-200 dark:border-neutral-700 p-5 transition-all duration-200 hover:border-primary dark:hover:border-primary-light hover:shadow-lg group relative"
523
+ role="listitem"
524
+ aria-label="<?php printf( esc_attr__( 'Widget: %s', 'sociallane-elements' ), esc_attr( $widget['display'] ) ); ?>"
525
+ >
526
+ <div class="flex flex-col h-full">
527
+ <?php // Widget Name ?>
528
+ <h3 class="<?php echo esc_attr( $classes['card_text'] ?? '' ); ?> text-lg font-semibold font-heading mb-2">
529
+ <?php echo esc_html( $widget['display'] ); ?>
530
+ </h3>
531
+
532
+ <?php // Category Badge ?>
533
+ <div class="flex items-center gap-2 mb-3">
534
+ <span class="<?php echo esc_attr( $classes['card_category'] ?? '' ); ?> text-xs font-medium uppercase tracking-wider">
535
+ <?php echo esc_html( $cat_label ); ?>
536
+ </span>
537
+ </div>
538
+
539
+ <?php // npm install command (full command visible, wraps if needed) ?>
540
+ <div class="mb-3 flex items-start gap-2 flex-wrap">
541
+ <code class="flex-1 min-w-0 text-xs <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> bg-neutral-100 dark:bg-neutral-700/50 rounded px-2 py-1.5 break-all whitespace-pre-wrap" data-npm-command="<?php echo esc_attr( $npm_cmd ); ?>"><?php echo esc_html( $npm_cmd ); ?></code>
542
+ <button
543
+ type="button"
544
+ data-copy-npm
545
+ data-npm-command="<?php echo esc_attr( $npm_cmd ); ?>"
546
+ class="shrink-0 inline-flex items-center gap-1 px-2 py-1 rounded text-xs font-medium bg-neutral-200 dark:bg-neutral-600 hover:bg-neutral-300 dark:hover:bg-neutral-500 focus:outline-none focus:ring-2 focus:ring-primary transition-colors"
547
+ aria-label="<?php esc_attr_e( 'Copy npm command', 'sociallane-elements' ); ?>"
548
+ >
549
+ <svg class="w-3.5 h-3.5" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z" /></svg>
550
+ <span data-copy-label><?php esc_html_e( 'Copy', 'sociallane-elements' ); ?></span>
551
+ </button>
552
+ </div>
553
+
554
+ <?php // Add to collection + Copy name + Preview ?>
555
+ <div class="mt-auto pt-3 border-t border-neutral-200 dark:border-neutral-700 flex flex-wrap items-center gap-2">
556
+ <label class="inline-flex items-center gap-2 text-sm <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> cursor-pointer">
557
+ <input type="checkbox" data-add-to-collection data-widget-name="<?php echo esc_attr( $widget['name'] ); ?>" data-display="<?php echo esc_attr( $widget['display'] ); ?>" data-npm-package="<?php echo esc_attr( $npm_pkg ); ?>" class="rounded border-neutral-300 dark:border-neutral-600 text-primary focus:ring-primary" />
558
+ <span><?php esc_html_e( 'Add to collection', 'sociallane-elements' ); ?></span>
559
+ </label>
560
+ <?php if ( ! empty( $view['preview_pages_enabled'] ) ) : ?>
561
+ <a
562
+ href="<?php echo esc_url( home_url( '/widget-preview/' . $widget['name'] . '/' ) ); ?>"
563
+ target="_blank"
564
+ rel="noopener noreferrer"
565
+ class="inline-flex items-center gap-2 text-sm <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> hover:text-primary dark:hover:text-primary-light transition-colors focus:outline-none focus:ring-2 focus:ring-primary rounded px-2 py-1 -mx-2 -my-1"
566
+ aria-label="<?php printf( esc_attr__( 'Preview widget: %s', 'sociallane-elements' ), esc_attr( $widget['display'] ) ); ?>"
567
+ >
568
+ <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
569
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z" /><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z" />
570
+ </svg>
571
+ <span><?php esc_html_e( 'Preview', 'sociallane-elements' ); ?></span>
572
+ </a>
573
+ <?php endif; ?>
574
+ <button
575
+ type="button"
576
+ data-copy="<?php echo esc_attr( $widget['name'] ); ?>"
577
+ class="copy-widget-btn inline-flex items-center gap-2 text-sm <?php echo esc_attr( $classes['subtext'] ?? '' ); ?> hover:text-primary dark:hover:text-primary-light transition-colors focus:outline-none focus:ring-2 focus:ring-primary rounded px-2 py-1 -mx-2 -my-1"
578
+ aria-label="<?php printf( esc_attr__( 'Copy widget name: %s', 'sociallane-elements' ), esc_attr( $widget['display'] ) ); ?>"
579
+ >
580
+ <svg class="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
581
+ <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z" />
582
+ </svg>
583
+ <span data-copy-label><?php esc_html_e( 'Copy Name', 'sociallane-elements' ); ?></span>
584
+ </button>
585
+ </div>
586
+ </div>
587
+ </article>
588
+ <?php endforeach; ?>
589
+ </div>
590
+
591
+ <?php // Hover preview panel: single iframe shown on card hover (when preview pages enabled) ?>
592
+ <?php if ( ! empty( $view['preview_pages_enabled'] ) ) : ?>
593
+ <?php
594
+ $hover_preview_w = 420;
595
+ $hover_preview_h = 280;
596
+ $hover_iframe_w = 600;
597
+ $hover_iframe_h = 400;
598
+ $hover_scale = min( $hover_preview_w / $hover_iframe_w, $hover_preview_h / $hover_iframe_h );
599
+ ?>
600
+ <div
601
+ id="<?php echo esc_attr( $block_id ); ?>-hover-preview"
602
+ data-hover-preview
603
+ class="fixed z-50 pointer-events-none invisible opacity-0 transition-opacity duration-150 rounded-xl overflow-hidden border-2 border-primary dark:border-primary-light bg-white dark:bg-neutral-800 shadow-2xl"
604
+ style="width: <?php echo (int) $hover_preview_w; ?>px; height: <?php echo (int) $hover_preview_h; ?>px;"
605
+ aria-hidden="true"
606
+ >
607
+ <div
608
+ class="origin-top-left bg-white"
609
+ style="width: <?php echo (int) $hover_iframe_w; ?>px; height: <?php echo (int) $hover_iframe_h; ?>px; transform: scale(<?php echo round( $hover_scale, 4 ); ?>);"
610
+ >
611
+ <iframe
612
+ data-hover-preview-iframe
613
+ title=""
614
+ class="bg-white border-0"
615
+ style="width: <?php echo (int) $hover_iframe_w; ?>px; height: <?php echo (int) $hover_iframe_h; ?>px; pointer-events: auto;"
616
+ ></iframe>
617
+ </div>
618
+ </div>
619
+ <?php endif; ?>
620
+ <?php else : ?>
621
+ <p class="<?php echo esc_attr( $classes['subtext'] ?? '' ); ?> text-center py-8">
622
+ <?php esc_html_e( 'No widgets found.', 'sociallane-elements' ); ?>
623
+ </p>
624
+ <?php endif; ?>
625
+ </main>
626
+ </div>
627
+ </div>
628
+ </section>
629
+
630
+ <?php // ========== WIDGET FILTER END ========== ?>