jigsaw_engine 0.4.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.
- checksums.yaml +7 -0
- data/README.md +18 -0
- data/Rakefile +6 -0
- data/app/assets/stylesheets/jigsaw/grid_resize.css +21 -0
- data/app/assets/stylesheets/jigsaw/layout_editor.css +356 -0
- data/app/components/custom_module_component.rb +38 -0
- data/app/controllers/jigsaw/application_controller.rb +5 -0
- data/app/controllers/jigsaw/dashboard_controller.rb +8 -0
- data/app/controllers/jigsaw/layout_templates_controller.rb +73 -0
- data/app/controllers/jigsaw/pages_controller.rb +114 -0
- data/app/controllers/jigsaw/slot_templates_controller.rb +71 -0
- data/app/controllers/jigsaw/slots_controller.rb +54 -0
- data/app/helpers/jigsaw/custom_module_helper.rb +7 -0
- data/app/helpers/jigsaw/pages_helper.rb +7 -0
- data/app/javascript/jigsaw/components/ui/button.js +53 -0
- data/app/javascript/jigsaw/components/ui/dropdown-menu.js +157 -0
- data/app/javascript/jigsaw/components/ui/sheet.js +122 -0
- data/app/javascript/jigsaw/components/ui/utils.js +8 -0
- data/app/javascript/jigsaw/controllers/custom_module_controller.js +75 -0
- data/app/javascript/jigsaw/controllers/custom_page_controller.js +23 -0
- data/app/javascript/jigsaw/controllers/flyout_resize_controller.js +60 -0
- data/app/javascript/jigsaw/controllers/grid_resize_controller.js +228 -0
- data/app/javascript/jigsaw/controllers/layout_editor_controller.js +502 -0
- data/app/javascript/jigsaw/controllers/module_editor_controller.js +146 -0
- data/app/javascript/jigsaw/controllers/monaco_editor_controller.js +49 -0
- data/app/javascript/jigsaw/lib/generate_layout_css.js +52 -0
- data/app/javascript/seeds/blocks/authentication-forms-1/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-1/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-1/render.jsx +80 -0
- data/app/javascript/seeds/blocks/authentication-forms-2/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-2/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-2/render.jsx +90 -0
- data/app/javascript/seeds/blocks/authentication-forms-3/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-3/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-3/render.jsx +94 -0
- data/app/javascript/seeds/blocks/authentication-forms-4/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-4/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-4/render.jsx +97 -0
- data/app/javascript/seeds/blocks/authentication-forms-5/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-5/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-5/render.jsx +82 -0
- data/app/javascript/seeds/blocks/authentication-forms-6/config.json +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-6/data.js +1 -0
- data/app/javascript/seeds/blocks/authentication-forms-6/render.jsx +34 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-1/render.jsx +98 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-10/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-10/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-10/render.jsx +181 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-11/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-11/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-11/render.jsx +184 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-12/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-12/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-12/render.jsx +180 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-13/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-13/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-13/render.jsx +151 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-14/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-14/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-14/render.jsx +169 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-15/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-15/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-15/render.jsx +115 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-16/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-16/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-16/render.jsx +128 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-17/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-17/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-17/render.jsx +84 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-18/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-18/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-18/render.jsx +139 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-19/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-19/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-19/render.jsx +146 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-2/render.jsx +163 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-20/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-20/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-20/render.jsx +71 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-3/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-3/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-3/render.jsx +122 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-4/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-4/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-4/render.jsx +136 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-5/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-5/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-5/render.jsx +294 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-6/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-6/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-6/render.jsx +139 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-7/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-7/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-7/render.jsx +219 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-8/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-8/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-8/render.jsx +249 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-9/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-9/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/charts-9/render.jsx +213 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-1/render.jsx +434 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/form-layouts-2/render.jsx +332 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-1/render.jsx +121 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-2/render.jsx +99 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-3/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-3/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/modal-dialogs-3/render.jsx +176 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-1/render.jsx +20 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-2/render.jsx +22 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-3/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-3/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/page-layouts-3/render.jsx +22 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sidebar-layouts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sidebar-layouts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sidebar-layouts-1/render.jsx +20 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-1/render.jsx +98 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-2/render.jsx +116 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-3/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-3/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/sign-in-forms-3/render.jsx +104 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-1/render.jsx +147 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-2/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-2/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-2/render.jsx +120 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-3/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-3/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-3/render.jsx +62 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-4/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-4/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-4/render.jsx +49 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-5/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-5/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-5/render.jsx +106 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-6/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-6/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-6/render.jsx +79 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-7/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-7/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-7/render.jsx +57 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-8/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-8/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/stat-cards-8/render.jsx +234 -0
- data/app/javascript/seeds/blocks/dashboard-ui/tables-1/config.json +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/tables-1/data.js +1 -0
- data/app/javascript/seeds/blocks/dashboard-ui/tables-1/render.jsx +295 -0
- data/app/javascript/seeds/blocks/datepicker-1/config.json +1 -0
- data/app/javascript/seeds/blocks/datepicker-1/data.js +1 -0
- data/app/javascript/seeds/blocks/datepicker-1/render.jsx +14 -0
- data/app/javascript/seeds/blocks/datepicker-2/config.json +1 -0
- data/app/javascript/seeds/blocks/datepicker-2/data.js +1 -0
- data/app/javascript/seeds/blocks/datepicker-2/render.jsx +29 -0
- data/app/javascript/seeds/blocks/datepicker-3/config.json +1 -0
- data/app/javascript/seeds/blocks/datepicker-3/data.js +1 -0
- data/app/javascript/seeds/blocks/datepicker-3/render.jsx +163 -0
- data/app/javascript/seeds/blocks/datepicker-4/config.json +1 -0
- data/app/javascript/seeds/blocks/datepicker-4/data.js +1 -0
- data/app/javascript/seeds/blocks/datepicker-4/render.jsx +192 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-1/render.jsx +723 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-2/render.jsx +508 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-3/render.jsx +632 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-4/render.jsx +1013 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-5/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-5/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/checkout-page-5/render.jsx +520 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-1/render.jsx +121 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-2/render.jsx +126 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-3/render.jsx +81 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-category-4/render.jsx +85 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-1/render.jsx +80 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-2/render.jsx +226 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-3/render.jsx +315 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-4/render.jsx +269 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-5/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-5/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-5/render.jsx +265 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-6/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-6/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-6/render.jsx +477 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-7/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-7/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-detail-7/render.jsx +405 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-1/render.jsx +71 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-features-2/render.jsx +135 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-1/render.jsx +87 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-2/render.jsx +151 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-3/render.jsx +313 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-4/render.jsx +223 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-5/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-5/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-5/render.jsx +200 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-6/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-6/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-6/render.jsx +177 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-7/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-7/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-7/render.jsx +175 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-8/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-8/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-list-8/render.jsx +231 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-1/render.jsx +64 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/product-quickview-2/render.jsx +62 -0
- data/app/javascript/seeds/blocks/ecommerce/promo-sections-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/promo-sections-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/promo-sections-1/render.jsx +75 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-1/render.jsx +197 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-2/render.jsx +143 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-3/render.jsx +225 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/shopping-cart-4/render.jsx +93 -0
- data/app/javascript/seeds/blocks/ecommerce/store-navigation-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce/store-navigation-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce/store-navigation-1/render.jsx +290 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-1/render.jsx +86 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-2/render.jsx +119 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-3/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-3/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-3/render.jsx +97 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-4/config.json +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-4/data.js +1 -0
- data/app/javascript/seeds/blocks/ecommerce-charts-4/render.jsx +108 -0
- data/app/javascript/seeds/blocks/line-charts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/line-charts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/line-charts-1/render.jsx +230 -0
- data/app/javascript/seeds/blocks/line-charts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/line-charts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/line-charts-2/render.jsx +118 -0
- data/app/javascript/seeds/blocks/line-charts-3/config.json +1 -0
- data/app/javascript/seeds/blocks/line-charts-3/data.js +1 -0
- data/app/javascript/seeds/blocks/line-charts-3/render.jsx +134 -0
- data/app/javascript/seeds/blocks/line-charts-4/config.json +1 -0
- data/app/javascript/seeds/blocks/line-charts-4/data.js +1 -0
- data/app/javascript/seeds/blocks/line-charts-4/render.jsx +115 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-1/render.jsx +31 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-10/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-10/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-10/render.jsx +76 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-2/render.jsx +78 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-3/render.jsx +50 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-4/render.jsx +24 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-5/render.jsx +66 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-6/render.jsx +69 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-7/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-7/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-7/render.jsx +43 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-8/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-8/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-8/render.jsx +63 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-9/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-9/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/call-to-action-9/render.jsx +27 -0
- data/app/javascript/seeds/blocks/marketing/changelog-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-1/render.jsx +106 -0
- data/app/javascript/seeds/blocks/marketing/changelog-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-2/render.jsx +157 -0
- data/app/javascript/seeds/blocks/marketing/changelog-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-3/render.jsx +204 -0
- data/app/javascript/seeds/blocks/marketing/changelog-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/changelog-4/render.jsx +199 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-1/render.jsx +155 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-10/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-10/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-10/render.jsx +83 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-11/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-11/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-11/render.jsx +338 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-12/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-12/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-12/render.jsx +96 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-13/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-13/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-13/render.jsx +77 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-2/render.jsx +117 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-3/render.jsx +105 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-4/render.jsx +127 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-5/render.jsx +78 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-6/render.jsx +79 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-7/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-7/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-7/render.jsx +138 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-8/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-8/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-8/render.jsx +215 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-9/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-9/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/feature-section-9/render.jsx +81 -0
- data/app/javascript/seeds/blocks/marketing/footers-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-1/render.jsx +106 -0
- data/app/javascript/seeds/blocks/marketing/footers-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-2/render.jsx +76 -0
- data/app/javascript/seeds/blocks/marketing/footers-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-3/render.jsx +160 -0
- data/app/javascript/seeds/blocks/marketing/footers-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-4/render.jsx +167 -0
- data/app/javascript/seeds/blocks/marketing/footers-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/footers-5/render.jsx +223 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-1/render.jsx +49 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-10/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-10/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-10/render.jsx +147 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-11/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-11/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-11/render.jsx +218 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-12/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-12/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-12/render.jsx +287 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-13/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-13/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-13/render.jsx +113 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-14/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-14/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-14/render.jsx +249 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-2/render.jsx +94 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-3/render.jsx +51 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-4/render.jsx +153 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-5/render.jsx +210 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-6/render.jsx +191 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-7/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-7/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-7/render.jsx +306 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-8/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-8/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-8/render.jsx +103 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-9/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-9/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/hero-section-9/render.jsx +354 -0
- data/app/javascript/seeds/blocks/marketing/integrations-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-1/render.jsx +483 -0
- data/app/javascript/seeds/blocks/marketing/integrations-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-2/render.jsx +468 -0
- data/app/javascript/seeds/blocks/marketing/integrations-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-3/render.jsx +441 -0
- data/app/javascript/seeds/blocks/marketing/integrations-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-4/render.jsx +433 -0
- data/app/javascript/seeds/blocks/marketing/integrations-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-5/render.jsx +477 -0
- data/app/javascript/seeds/blocks/marketing/integrations-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/integrations-6/render.jsx +468 -0
- data/app/javascript/seeds/blocks/marketing/navbars-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-1/render.jsx +133 -0
- data/app/javascript/seeds/blocks/marketing/navbars-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-2/render.jsx +95 -0
- data/app/javascript/seeds/blocks/marketing/navbars-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/navbars-3/render.jsx +246 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-1/render.jsx +45 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-2/render.jsx +55 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/newsletter-sections-3/render.jsx +29 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-1/render.jsx +110 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-2/render.jsx +71 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-3/render.jsx +124 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-4/render.jsx +205 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-5/render.jsx +143 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-6/render.jsx +195 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-7/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-7/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/pricing-table-7/render.jsx +351 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-1/render.jsx +71 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-2/render.jsx +125 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-3/render.jsx +136 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-4/render.jsx +107 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/team-sections-5/render.jsx +124 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-1/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-1/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-1/render.jsx +112 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-10/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-10/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-10/render.jsx +106 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-11/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-11/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-11/render.jsx +79 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-12/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-12/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-12/render.jsx +173 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-13/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-13/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-13/render.jsx +121 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-14/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-14/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-14/render.jsx +158 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-15/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-15/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-15/render.jsx +109 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-2/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-2/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-2/render.jsx +81 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-3/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-3/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-3/render.jsx +149 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-4/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-4/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-4/render.jsx +148 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-5/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-5/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-5/render.jsx +153 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-6/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-6/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-6/render.jsx +155 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-7/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-7/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-7/render.jsx +102 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-8/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-8/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-8/render.jsx +161 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-9/config.json +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-9/data.js +1 -0
- data/app/javascript/seeds/blocks/marketing/testimonials-9/render.jsx +195 -0
- data/app/javascript/seeds/blocks/project-management-charts-1/config.json +1 -0
- data/app/javascript/seeds/blocks/project-management-charts-1/data.js +1 -0
- data/app/javascript/seeds/blocks/project-management-charts-1/render.jsx +172 -0
- data/app/javascript/seeds/blocks/project-management-charts-2/config.json +1 -0
- data/app/javascript/seeds/blocks/project-management-charts-2/data.js +1 -0
- data/app/javascript/seeds/blocks/project-management-charts-2/render.jsx +147 -0
- data/app/javascript/seeds/blocks/switch-cards-1/config.json +1 -0
- data/app/javascript/seeds/blocks/switch-cards-1/data.js +1 -0
- data/app/javascript/seeds/blocks/switch-cards-1/render.jsx +116 -0
- data/app/javascript/seeds/blocks/theme-switchers-1/config.json +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-1/data.js +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-1/render.jsx +22 -0
- data/app/javascript/seeds/blocks/theme-switchers-2/config.json +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-2/data.js +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-2/render.jsx +51 -0
- data/app/javascript/seeds/blocks/theme-switchers-3/config.json +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-3/data.js +1 -0
- data/app/javascript/seeds/blocks/theme-switchers-3/render.jsx +37 -0
- data/app/javascript/seeds/examples/blog-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/blog-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/blog-cards-1/render.jsx +81 -0
- data/app/javascript/seeds/examples/blog-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/blog-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/blog-cards-2/render.jsx +78 -0
- data/app/javascript/seeds/examples/blog-cards-3/config.json +1 -0
- data/app/javascript/seeds/examples/blog-cards-3/data.js +1 -0
- data/app/javascript/seeds/examples/blog-cards-3/render.jsx +80 -0
- data/app/javascript/seeds/examples/blog-cards-4/config.json +1 -0
- data/app/javascript/seeds/examples/blog-cards-4/data.js +1 -0
- data/app/javascript/seeds/examples/blog-cards-4/render.jsx +32 -0
- data/app/javascript/seeds/examples/chat-bubbles-1/config.json +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-1/data.js +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-1/render.jsx +154 -0
- data/app/javascript/seeds/examples/chat-bubbles-2/config.json +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-2/data.js +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-2/render.jsx +88 -0
- data/app/javascript/seeds/examples/chat-bubbles-3/config.json +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-3/data.js +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-3/render.jsx +90 -0
- data/app/javascript/seeds/examples/chat-bubbles-4/config.json +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-4/data.js +1 -0
- data/app/javascript/seeds/examples/chat-bubbles-4/render.jsx +169 -0
- data/app/javascript/seeds/examples/payment-methods-1/config.json +1 -0
- data/app/javascript/seeds/examples/payment-methods-1/data.js +1 -0
- data/app/javascript/seeds/examples/payment-methods-1/render.jsx +128 -0
- data/app/javascript/seeds/examples/payment-methods-2/config.json +1 -0
- data/app/javascript/seeds/examples/payment-methods-2/data.js +1 -0
- data/app/javascript/seeds/examples/payment-methods-2/render.jsx +80 -0
- data/app/javascript/seeds/examples/payment-methods-3/config.json +1 -0
- data/app/javascript/seeds/examples/payment-methods-3/data.js +1 -0
- data/app/javascript/seeds/examples/payment-methods-3/render.jsx +1 -0
- data/app/javascript/seeds/examples/product-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-1/render.jsx +48 -0
- data/app/javascript/seeds/examples/product-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-2/render.jsx +53 -0
- data/app/javascript/seeds/examples/product-cards-3/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-3/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-3/render.jsx +102 -0
- data/app/javascript/seeds/examples/product-cards-4/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-4/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-4/render.jsx +40 -0
- data/app/javascript/seeds/examples/product-cards-5/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-5/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-5/render.jsx +79 -0
- data/app/javascript/seeds/examples/product-cards-6/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-6/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-6/render.jsx +180 -0
- data/app/javascript/seeds/examples/product-cards-7/config.json +1 -0
- data/app/javascript/seeds/examples/product-cards-7/data.js +1 -0
- data/app/javascript/seeds/examples/product-cards-7/render.jsx +181 -0
- data/app/javascript/seeds/examples/product-list-1/config.json +1 -0
- data/app/javascript/seeds/examples/product-list-1/data.js +1 -0
- data/app/javascript/seeds/examples/product-list-1/render.jsx +114 -0
- data/app/javascript/seeds/examples/review-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/review-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/review-cards-1/render.jsx +54 -0
- data/app/javascript/seeds/examples/review-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/review-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/review-cards-2/render.jsx +68 -0
- data/app/javascript/seeds/examples/review-cards-3/config.json +1 -0
- data/app/javascript/seeds/examples/review-cards-3/data.js +1 -0
- data/app/javascript/seeds/examples/review-cards-3/render.jsx +101 -0
- data/app/javascript/seeds/examples/social-media-post-1/config.json +1 -0
- data/app/javascript/seeds/examples/social-media-post-1/data.js +1 -0
- data/app/javascript/seeds/examples/social-media-post-1/render.jsx +162 -0
- data/app/javascript/seeds/examples/social-media-post-2/config.json +1 -0
- data/app/javascript/seeds/examples/social-media-post-2/data.js +1 -0
- data/app/javascript/seeds/examples/social-media-post-2/render.jsx +172 -0
- data/app/javascript/seeds/examples/social-media-post-3/config.json +1 -0
- data/app/javascript/seeds/examples/social-media-post-3/data.js +1 -0
- data/app/javascript/seeds/examples/social-media-post-3/render.jsx +270 -0
- data/app/javascript/seeds/examples/social-media-post-4/config.json +1 -0
- data/app/javascript/seeds/examples/social-media-post-4/data.js +1 -0
- data/app/javascript/seeds/examples/social-media-post-4/render.jsx +188 -0
- data/app/javascript/seeds/examples/stat-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/stat-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/stat-cards-1/render.jsx +31 -0
- data/app/javascript/seeds/examples/stat-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/stat-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/stat-cards-2/render.jsx +42 -0
- data/app/javascript/seeds/examples/stat-cards-3/config.json +1 -0
- data/app/javascript/seeds/examples/stat-cards-3/data.js +1 -0
- data/app/javascript/seeds/examples/stat-cards-3/render.jsx +114 -0
- data/app/javascript/seeds/examples/stat-cards-4/config.json +1 -0
- data/app/javascript/seeds/examples/stat-cards-4/data.js +1 -0
- data/app/javascript/seeds/examples/stat-cards-4/render.jsx +117 -0
- data/app/javascript/seeds/examples/task-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/task-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/task-cards-1/render.jsx +133 -0
- data/app/javascript/seeds/examples/task-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/task-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/task-cards-2/render.jsx +122 -0
- data/app/javascript/seeds/examples/welcome-cards-1/config.json +1 -0
- data/app/javascript/seeds/examples/welcome-cards-1/data.js +1 -0
- data/app/javascript/seeds/examples/welcome-cards-1/render.jsx +40 -0
- data/app/javascript/seeds/examples/welcome-cards-2/config.json +1 -0
- data/app/javascript/seeds/examples/welcome-cards-2/data.js +1 -0
- data/app/javascript/seeds/examples/welcome-cards-2/render.jsx +58 -0
- data/app/javascript/seeds/examples/welcome-cards-3/config.json +1 -0
- data/app/javascript/seeds/examples/welcome-cards-3/data.js +1 -0
- data/app/javascript/seeds/examples/welcome-cards-3/render.jsx +91 -0
- data/app/javascript/seeds/ide-editor/config.json +4 -0
- data/app/javascript/seeds/ide-editor/data.js +16 -0
- data/app/javascript/seeds/ide-editor/render.jsx +132 -0
- data/app/javascript/seeds/ide-file-tree/config.json +4 -0
- data/app/javascript/seeds/ide-file-tree/data.js +50 -0
- data/app/javascript/seeds/ide-file-tree/render.jsx +426 -0
- data/app/javascript/seeds/ide-preview/config.json +4 -0
- data/app/javascript/seeds/ide-preview/data.js +4 -0
- data/app/javascript/seeds/ide-preview/render.jsx +49 -0
- data/app/javascript/seeds/ide-terminal/config.json +4 -0
- data/app/javascript/seeds/ide-terminal/data.js +4 -0
- data/app/javascript/seeds/ide-terminal/render.jsx +247 -0
- data/app/javascript/seeds/main-menu/config.json +9 -0
- data/app/javascript/seeds/main-menu/data.js +6 -0
- data/app/javascript/seeds/main-menu/render.jsx +70 -0
- data/app/models/concerns/jigsaw/grid_configurable.rb +89 -0
- data/app/models/concerns/jigsaw/slot_compilable.rb +69 -0
- data/app/models/jigsaw/application_record.rb +5 -0
- data/app/models/jigsaw/layout.rb +61 -0
- data/app/models/jigsaw/layout_template.rb +16 -0
- data/app/models/jigsaw/page.rb +35 -0
- data/app/models/jigsaw/schemas/layout_config.json +54 -0
- data/app/models/jigsaw/slot.rb +109 -0
- data/app/models/jigsaw/slot_template.rb +29 -0
- data/app/views/jigsaw/dashboard/index.html.ruby +23 -0
- data/app/views/jigsaw/layout_templates/_form.html.ruby +69 -0
- data/app/views/jigsaw/layout_templates/edit.html.ruby +72 -0
- data/app/views/jigsaw/layout_templates/index.html.ruby +48 -0
- data/app/views/jigsaw/layout_templates/new.html.ruby +19 -0
- data/app/views/jigsaw/pages/_form.html.ruby +75 -0
- data/app/views/jigsaw/pages/edit.html.ruby +104 -0
- data/app/views/jigsaw/pages/index.html.ruby +65 -0
- data/app/views/jigsaw/pages/new.html.ruby +34 -0
- data/app/views/jigsaw/pages/show.html.ruby +28 -0
- data/app/views/jigsaw/slot_templates/edit.html.ruby +42 -0
- data/app/views/jigsaw/slot_templates/index.html.ruby +73 -0
- data/app/views/jigsaw/slot_templates/new.html.ruby +21 -0
- data/app/views/jigsaw/slot_templates/show.html.ruby +38 -0
- data/app/views/jigsaw/slots/_shared/_menu.html.ruby +7 -0
- data/app/views/jigsaw/slots/edit.html.ruby +52 -0
- data/app/views/jigsaw/slots/index.html.ruby +17 -0
- data/app/views/layouts/jigsaw/application.html.ruby +31 -0
- data/config/importmap.rb +35 -0
- data/config/routes.rb +27 -0
- data/db/migrate/20260505185636_create_jigsaw_custom_pages.rb +12 -0
- data/db/migrate/20260505185637_create_jigsaw_data_functions.rb +15 -0
- data/db/migrate/20260505185638_create_jigsaw_render_functions.rb +15 -0
- data/db/migrate/20260505185639_create_jigsaw_page_modules.rb +15 -0
- data/db/migrate/20260505185640_create_jigsaw_layouts.rb +14 -0
- data/db/migrate/20260506000001_remove_slot_from_jigsaw_page_modules.rb +5 -0
- data/db/migrate/20260506000002_make_page_module_functions_optional.rb +6 -0
- data/db/migrate/20260506000003_inline_functions_on_page_modules.rb +55 -0
- data/db/migrate/20260507000001_move_layout_fk_to_layouts_table.rb +30 -0
- data/db/migrate/20260507000002_move_page_modules_to_layouts.rb +30 -0
- data/db/migrate/20260508000001_rename_custom_pages_to_pages.rb +18 -0
- data/db/migrate/20260508000002_rename_page_modules_to_slots.rb +7 -0
- data/db/migrate/20260509000001_create_jigsaw_templates.rb +13 -0
- data/db/migrate/20260509000002_create_jigsaw_template_layouts.rb +12 -0
- data/db/migrate/20260509000003_create_jigsaw_template_slots.rb +22 -0
- data/db/migrate/20260509000004_add_template_linking_to_layouts.rb +6 -0
- data/db/migrate/20260509000005_add_linked_to_template_to_slots.rb +5 -0
- data/db/migrate/20260510000001_refactor_templates_to_layout_and_slot_templates.rb +104 -0
- data/db/seeds/01_pages.rb +69 -0
- data/db/seeds/02_main_menu_slot.rb +15 -0
- data/db/seeds/03_webcontainer_ide.rb +51 -0
- data/db/seeds.rb +120 -0
- data/lib/jigsaw/engine.rb +29 -0
- data/lib/jigsaw/grid_layout_generator.rb +55 -0
- data/lib/jigsaw/jsx_compiler.rb +21 -0
- data/lib/jigsaw/version.rb +3 -0
- data/lib/jigsaw/version.rb.erb +3 -0
- data/lib/jigsaw.rb +11 -0
- data/lib/jigsaw_engine.rb +4 -0
- data/lib/tasks/kube_tasks.rake +4 -0
- data/lib/tasks/shadcn.rake +171 -0
- metadata +1033 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function(shared, config) { return config }
|
|
@@ -0,0 +1,520 @@
|
|
|
1
|
+
i"use client";
|
|
2
|
+
|
|
3
|
+
import Image from "next/image";
|
|
4
|
+
import { useMemo, useState } from "react";
|
|
5
|
+
import { ArrowLeft, Info, Shield } from "lucide-react";
|
|
6
|
+
import { z } from "zod";
|
|
7
|
+
|
|
8
|
+
import { Button } from "@/components/ui/button";
|
|
9
|
+
import {
|
|
10
|
+
Dialog,
|
|
11
|
+
DialogContent,
|
|
12
|
+
DialogHeader,
|
|
13
|
+
DialogTitle,
|
|
14
|
+
DialogTrigger,
|
|
15
|
+
} from "@/components/ui/dialog";
|
|
16
|
+
import { Input } from "@/components/ui/input";
|
|
17
|
+
import {
|
|
18
|
+
InputGroup,
|
|
19
|
+
InputGroupAddon,
|
|
20
|
+
InputGroupButton,
|
|
21
|
+
InputGroupInput,
|
|
22
|
+
} from "@/components/ui/input-group";
|
|
23
|
+
import { Separator } from "@/components/ui/separator";
|
|
24
|
+
import { Badge } from "@/components/ui/badge";
|
|
25
|
+
import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
|
|
26
|
+
import { Label } from "@/components/ui/label";
|
|
27
|
+
import {
|
|
28
|
+
Tooltip,
|
|
29
|
+
TooltipContent,
|
|
30
|
+
TooltipProvider,
|
|
31
|
+
TooltipTrigger,
|
|
32
|
+
} from "@/components/ui/tooltip";
|
|
33
|
+
|
|
34
|
+
type CartItem = {
|
|
35
|
+
id: number;
|
|
36
|
+
name: string;
|
|
37
|
+
size: string;
|
|
38
|
+
color: string;
|
|
39
|
+
imageSrc: string;
|
|
40
|
+
imageAlt: string;
|
|
41
|
+
price: number;
|
|
42
|
+
quantity: number;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
const initialItems: CartItem[] = [
|
|
46
|
+
{
|
|
47
|
+
id: 1,
|
|
48
|
+
name: "Samba OG shoes",
|
|
49
|
+
size: "8.5",
|
|
50
|
+
color: "Cloud White",
|
|
51
|
+
imageSrc:
|
|
52
|
+
"https://images.unsplash.com/photo-1542291026-7eec264c27ff?auto=format&fit=crop&w=600&q=80",
|
|
53
|
+
imageAlt: "Samba OG shoes",
|
|
54
|
+
price: 100,
|
|
55
|
+
quantity: 1,
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
id: 2,
|
|
59
|
+
name: "New Balance MT580",
|
|
60
|
+
size: "8.5",
|
|
61
|
+
color: "White Sea Salt",
|
|
62
|
+
imageSrc:
|
|
63
|
+
"https://images.unsplash.com/photo-1549298916-b41d501d3772?auto=format&fit=crop&w=600&q=80",
|
|
64
|
+
imageAlt: "New Balance MT580 shoes",
|
|
65
|
+
price: 170,
|
|
66
|
+
quantity: 1,
|
|
67
|
+
},
|
|
68
|
+
];
|
|
69
|
+
|
|
70
|
+
function formatPrice(value: number) {
|
|
71
|
+
return new Intl.NumberFormat("en-US", {
|
|
72
|
+
style: "currency",
|
|
73
|
+
currency: "USD",
|
|
74
|
+
minimumFractionDigits: 2,
|
|
75
|
+
maximumFractionDigits: 2,
|
|
76
|
+
}).format(value);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
function formatCardNumber(value: string) {
|
|
80
|
+
const digits = value.replace(/\D/g, "").slice(0, 16);
|
|
81
|
+
return digits.replace(/(.{4})/g, "$1 ").trim();
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function formatExpiry(value: string) {
|
|
85
|
+
const digits = value.replace(/\D/g, "").slice(0, 4);
|
|
86
|
+
|
|
87
|
+
if (digits.length <= 2) {
|
|
88
|
+
return digits;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return `${digits.slice(0, 2)}/${digits.slice(2)}`;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function normalizeExpiryMonth(value: string) {
|
|
95
|
+
const [month = "", year = ""] = value.split("/");
|
|
96
|
+
if (!month) {
|
|
97
|
+
return value;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
const numericMonth = Math.min(Math.max(Number(month), 1), 12);
|
|
101
|
+
const normalizedMonth = String(numericMonth).padStart(2, "0");
|
|
102
|
+
return year ? `${normalizedMonth}/${year}` : normalizedMonth;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
const paymentDetailsSchema = z.object({
|
|
106
|
+
cardNumber: z.string().regex(/^\d{16}$/, "Card number must be 16 digits"),
|
|
107
|
+
cardExpiry: z
|
|
108
|
+
.string()
|
|
109
|
+
.regex(/^(0[1-9]|1[0-2])\/\d{2}$/, "Expiry must be in MM/YY format"),
|
|
110
|
+
cardCvc: z.string().regex(/^\d{3,4}$/, "CVV must be 3 or 4 digits"),
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
export default function CheckoutPage5() {
|
|
114
|
+
const [open, setOpen] = useState(true);
|
|
115
|
+
const [paymentOpen, setPaymentOpen] = useState(false);
|
|
116
|
+
const [items, setItems] = useState(initialItems);
|
|
117
|
+
const [promoCode, setPromoCode] = useState("");
|
|
118
|
+
const [appliedDiscount, setAppliedDiscount] = useState(0);
|
|
119
|
+
const [selectedSavedCard, setSelectedSavedCard] = useState("mastercard");
|
|
120
|
+
const [cardNumber, setCardNumber] = useState("");
|
|
121
|
+
const [cardExpiry, setCardExpiry] = useState("");
|
|
122
|
+
const [cardCvc, setCardCvc] = useState("");
|
|
123
|
+
const [paymentErrors, setPaymentErrors] = useState<{
|
|
124
|
+
cardNumber?: string;
|
|
125
|
+
cardExpiry?: string;
|
|
126
|
+
cardCvc?: string;
|
|
127
|
+
}>({});
|
|
128
|
+
|
|
129
|
+
const subtotal = useMemo(
|
|
130
|
+
() => items.reduce((sum, item) => sum + item.price * item.quantity, 0),
|
|
131
|
+
[items],
|
|
132
|
+
);
|
|
133
|
+
|
|
134
|
+
const deliveryCost = 12.99;
|
|
135
|
+
const total = Math.max(subtotal + deliveryCost - appliedDiscount, 0);
|
|
136
|
+
|
|
137
|
+
const updateQuantity = (id: number, quantity: number) => {
|
|
138
|
+
setItems((prev) =>
|
|
139
|
+
prev.map((item) =>
|
|
140
|
+
item.id === id ? { ...item, quantity: Math.max(1, quantity) } : item,
|
|
141
|
+
),
|
|
142
|
+
);
|
|
143
|
+
};
|
|
144
|
+
|
|
145
|
+
const handleApplyCode = () => {
|
|
146
|
+
const normalizedCode = promoCode.trim();
|
|
147
|
+
if (!normalizedCode) {
|
|
148
|
+
setAppliedDiscount(0);
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
// Mock behavior: any non-empty code applies a flat discount.
|
|
153
|
+
setAppliedDiscount(20);
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
const handleRemoveCode = () => {
|
|
157
|
+
setPromoCode("");
|
|
158
|
+
setAppliedDiscount(0);
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
const handlePayNow = (event: React.FormEvent<HTMLFormElement>) => {
|
|
162
|
+
event.preventDefault();
|
|
163
|
+
|
|
164
|
+
const normalizedPaymentData = {
|
|
165
|
+
cardNumber: cardNumber.replace(/\D/g, ""),
|
|
166
|
+
cardExpiry,
|
|
167
|
+
cardCvc: cardCvc.replace(/\D/g, ""),
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
const validationResult = paymentDetailsSchema.safeParse(
|
|
171
|
+
normalizedPaymentData,
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
if (!validationResult.success) {
|
|
175
|
+
const fieldErrors = validationResult.error.flatten().fieldErrors;
|
|
176
|
+
setPaymentErrors({
|
|
177
|
+
cardNumber: fieldErrors.cardNumber?.[0],
|
|
178
|
+
cardExpiry: fieldErrors.cardExpiry?.[0],
|
|
179
|
+
cardCvc: fieldErrors.cardCvc?.[0],
|
|
180
|
+
});
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
setPaymentErrors({});
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
return (
|
|
188
|
+
<section className="flex h-screen w-full items-center justify-center">
|
|
189
|
+
<Dialog open={open} onOpenChange={setOpen}>
|
|
190
|
+
<DialogTrigger asChild>
|
|
191
|
+
<Button>Payment</Button>
|
|
192
|
+
</DialogTrigger>
|
|
193
|
+
<DialogContent>
|
|
194
|
+
<DialogHeader>
|
|
195
|
+
<DialogTitle>Your Cart</DialogTitle>
|
|
196
|
+
</DialogHeader>
|
|
197
|
+
<div className="space-y-6 pt-4">
|
|
198
|
+
<div className="space-y-4">
|
|
199
|
+
{items.map((item) => (
|
|
200
|
+
<div key={item.id} className="flex gap-4">
|
|
201
|
+
<Image
|
|
202
|
+
src={item.imageSrc}
|
|
203
|
+
alt={item.imageAlt}
|
|
204
|
+
width={96}
|
|
205
|
+
height={96}
|
|
206
|
+
className="aspect-square h-full w-full max-w-12 rounded-md object-cover sm:max-w-16"
|
|
207
|
+
unoptimized
|
|
208
|
+
/>
|
|
209
|
+
<div className="min-w-0 flex-1 space-y-2">
|
|
210
|
+
<div className="flex items-center justify-between gap-4">
|
|
211
|
+
<div className="min-w-0 space-y-1">
|
|
212
|
+
<p className="truncate font-semibold">{item.name}</p>
|
|
213
|
+
<p className="text-muted-foreground flex gap-2 text-sm">
|
|
214
|
+
Size {item.size}
|
|
215
|
+
<Badge variant="outline">{item.color}</Badge>
|
|
216
|
+
</p>
|
|
217
|
+
</div>
|
|
218
|
+
<div className="space-y-2 text-right">
|
|
219
|
+
<p className="text-sm font-medium">
|
|
220
|
+
{formatPrice(item.price)}
|
|
221
|
+
</p>
|
|
222
|
+
<InputGroup
|
|
223
|
+
className="ml-auto max-w-24"
|
|
224
|
+
aria-label="Quantity"
|
|
225
|
+
>
|
|
226
|
+
<InputGroupAddon align="inline-start">
|
|
227
|
+
<InputGroupButton
|
|
228
|
+
aria-label="Decrease quantity"
|
|
229
|
+
onClick={() =>
|
|
230
|
+
updateQuantity(item.id, item.quantity - 1)
|
|
231
|
+
}
|
|
232
|
+
>
|
|
233
|
+
-
|
|
234
|
+
</InputGroupButton>
|
|
235
|
+
</InputGroupAddon>
|
|
236
|
+
<InputGroupInput
|
|
237
|
+
value={String(item.quantity)}
|
|
238
|
+
readOnly
|
|
239
|
+
inputMode="numeric"
|
|
240
|
+
className="text-center text-lg tabular-nums"
|
|
241
|
+
/>
|
|
242
|
+
<InputGroupAddon align="inline-end">
|
|
243
|
+
<InputGroupButton
|
|
244
|
+
aria-label="Increase quantity"
|
|
245
|
+
onClick={() =>
|
|
246
|
+
updateQuantity(item.id, item.quantity + 1)
|
|
247
|
+
}
|
|
248
|
+
>
|
|
249
|
+
+
|
|
250
|
+
</InputGroupButton>
|
|
251
|
+
</InputGroupAddon>
|
|
252
|
+
</InputGroup>
|
|
253
|
+
</div>
|
|
254
|
+
</div>
|
|
255
|
+
</div>
|
|
256
|
+
</div>
|
|
257
|
+
))}
|
|
258
|
+
</div>
|
|
259
|
+
|
|
260
|
+
<Separator />
|
|
261
|
+
|
|
262
|
+
<div className="space-y-2">
|
|
263
|
+
<p className="font-medium">Have a promotion code?</p>
|
|
264
|
+
<InputGroup>
|
|
265
|
+
<InputGroupInput
|
|
266
|
+
placeholder="Enter Code"
|
|
267
|
+
value={promoCode}
|
|
268
|
+
onChange={(event) => {
|
|
269
|
+
const nextValue = event.target.value;
|
|
270
|
+
setPromoCode(nextValue);
|
|
271
|
+
if (!nextValue.trim()) {
|
|
272
|
+
setAppliedDiscount(0);
|
|
273
|
+
}
|
|
274
|
+
}}
|
|
275
|
+
/>
|
|
276
|
+
<InputGroupAddon align="inline-end">
|
|
277
|
+
<InputGroupButton
|
|
278
|
+
type="button"
|
|
279
|
+
variant="outline"
|
|
280
|
+
onClick={
|
|
281
|
+
appliedDiscount > 0 ? handleRemoveCode : handleApplyCode
|
|
282
|
+
}
|
|
283
|
+
>
|
|
284
|
+
{appliedDiscount > 0 ? "Remove" : "Apply Code"}
|
|
285
|
+
</InputGroupButton>
|
|
286
|
+
</InputGroupAddon>
|
|
287
|
+
</InputGroup>
|
|
288
|
+
</div>
|
|
289
|
+
|
|
290
|
+
<Separator />
|
|
291
|
+
|
|
292
|
+
<div className="space-y-4">
|
|
293
|
+
<h3 className="font-medium">Order Summary</h3>
|
|
294
|
+
<dl className="space-y-2 text-sm">
|
|
295
|
+
<div className="flex items-center justify-between">
|
|
296
|
+
<dt className="text-muted-foreground">
|
|
297
|
+
{items.length} {items.length === 1 ? "item" : "items"}
|
|
298
|
+
</dt>
|
|
299
|
+
<dd>{formatPrice(subtotal)}</dd>
|
|
300
|
+
</div>
|
|
301
|
+
<div className="flex items-center justify-between">
|
|
302
|
+
<dt className="text-muted-foreground inline-flex items-center gap-1">
|
|
303
|
+
Delivery Cost
|
|
304
|
+
<TooltipProvider>
|
|
305
|
+
<Tooltip>
|
|
306
|
+
<TooltipTrigger asChild>
|
|
307
|
+
<button
|
|
308
|
+
type="button"
|
|
309
|
+
aria-label="Delivery cost details"
|
|
310
|
+
className="inline-flex"
|
|
311
|
+
>
|
|
312
|
+
<Info className="size-3" />
|
|
313
|
+
</button>
|
|
314
|
+
</TooltipTrigger>
|
|
315
|
+
<TooltipContent>
|
|
316
|
+
<p>Standard shipping fee for this order.</p>
|
|
317
|
+
</TooltipContent>
|
|
318
|
+
</Tooltip>
|
|
319
|
+
</TooltipProvider>
|
|
320
|
+
</dt>
|
|
321
|
+
<dd>{formatPrice(deliveryCost)}</dd>
|
|
322
|
+
</div>
|
|
323
|
+
{appliedDiscount > 0 && (
|
|
324
|
+
<div className="flex items-center justify-between text-emerald-600">
|
|
325
|
+
<dt>Discount</dt>
|
|
326
|
+
<dd>-{formatPrice(appliedDiscount)}</dd>
|
|
327
|
+
</div>
|
|
328
|
+
)}
|
|
329
|
+
<div className="flex items-center justify-between">
|
|
330
|
+
<p className="font-semibold">Total</p>
|
|
331
|
+
<p className="font-semibold">{formatPrice(total)}</p>
|
|
332
|
+
</div>
|
|
333
|
+
</dl>
|
|
334
|
+
</div>
|
|
335
|
+
|
|
336
|
+
<Button
|
|
337
|
+
className="w-full"
|
|
338
|
+
size="lg"
|
|
339
|
+
type="button"
|
|
340
|
+
onClick={() => {
|
|
341
|
+
setOpen(false);
|
|
342
|
+
setPaymentOpen(true);
|
|
343
|
+
}}
|
|
344
|
+
>
|
|
345
|
+
Confirm Checkout
|
|
346
|
+
</Button>
|
|
347
|
+
</div>
|
|
348
|
+
</DialogContent>
|
|
349
|
+
</Dialog>
|
|
350
|
+
|
|
351
|
+
<Dialog open={paymentOpen} onOpenChange={setPaymentOpen}>
|
|
352
|
+
<DialogContent showCloseButton={false}>
|
|
353
|
+
<DialogHeader className="flex flex-row items-center gap-3">
|
|
354
|
+
<Button
|
|
355
|
+
variant="outline"
|
|
356
|
+
size="icon-sm"
|
|
357
|
+
type="button"
|
|
358
|
+
onClick={() => {
|
|
359
|
+
setPaymentOpen(false);
|
|
360
|
+
setOpen(true);
|
|
361
|
+
}}
|
|
362
|
+
aria-label="Go back"
|
|
363
|
+
>
|
|
364
|
+
<ArrowLeft />
|
|
365
|
+
</Button>
|
|
366
|
+
<DialogTitle>Payment Method</DialogTitle>
|
|
367
|
+
</DialogHeader>
|
|
368
|
+
<form className="space-y-6" onSubmit={handlePayNow}>
|
|
369
|
+
<div className="space-y-3">
|
|
370
|
+
<h3 className="font-medium">Saved Payment</h3>
|
|
371
|
+
<RadioGroup
|
|
372
|
+
className="w-full gap-2"
|
|
373
|
+
value={selectedSavedCard}
|
|
374
|
+
onValueChange={setSelectedSavedCard}
|
|
375
|
+
>
|
|
376
|
+
<div className="border-input has-data-[state=checked]:border-primary/50 relative flex w-full items-center gap-3 rounded-md border p-4 shadow-xs outline-none">
|
|
377
|
+
<img
|
|
378
|
+
className="size-12 rounded-md border p-1"
|
|
379
|
+
src="data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%20id%3D%22Layer_1%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20152.4%20108%22%20style%3D%22enable-background%3Anew%200%200%20152.4%20108%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E.st0%7Bfill%3Anone%3B%7D.st1%7Bfill%3A%23FF5F00%3B%7D.st2%7Bfill%3A%23EB001B%3B%7D.st3%7Bfill%3A%23F79E1B%3B%7D%3C%2Fstyle%3E%3Cg%3E%3Crect%20y%3D%220%22%20class%3D%22st0%22%20width%3D%22152.4%22%20height%3D%22108%22%2F%3E%3Cg%3E%3Crect%20x%3D%2260.4%22%20y%3D%2225.7%22%20class%3D%22st1%22%20width%3D%2231.5%22%20height%3D%2256.6%22%2F%3E%3Cpath%20class%3D%22st2%22%20d%3D%22M62.4%2C54c0-11%2C5.1-21.5%2C13.7-28.3c-15.6-12.3-38.3-9.6-50.6%2C6.1C13.3%2C47.4%2C16%2C70%2C31.7%2C82.3%20%20%20%20c13.1%2C10.3%2C31.4%2C10.3%2C44.5%2C0C67.5%2C75.5%2C62.4%2C65%2C62.4%2C54z%22%2F%3E%3Cpath%20class%3D%22st3%22%20d%3D%22M134.4%2C54c0%2C19.9-16.1%2C36-36%2C36c-8.1%2C0-15.9-2.7-22.2-7.7c15.6-12.3%2C18.3-34.9%2C6-50.6c-1.8-2.2-3.8-4.3-6-6%20%20%20%20c15.6-12.3%2C38.3-9.6%2C50.5%2C6.1C131.7%2C38.1%2C134.4%2C45.9%2C134.4%2C54z%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E"
|
|
380
|
+
alt=""
|
|
381
|
+
/>
|
|
382
|
+
<div className="grid grow gap-2">
|
|
383
|
+
<Label
|
|
384
|
+
htmlFor="saved-card-mastercard"
|
|
385
|
+
className="justify-between"
|
|
386
|
+
>
|
|
387
|
+
Master Card
|
|
388
|
+
</Label>
|
|
389
|
+
<p
|
|
390
|
+
id="saved-card-mastercard-description"
|
|
391
|
+
className="text-muted-foreground text-xs"
|
|
392
|
+
>
|
|
393
|
+
**** **** 1300
|
|
394
|
+
</p>
|
|
395
|
+
</div>
|
|
396
|
+
<RadioGroupItem
|
|
397
|
+
value="mastercard"
|
|
398
|
+
id="saved-card-mastercard"
|
|
399
|
+
aria-describedby="saved-card-mastercard-description"
|
|
400
|
+
className="size-5 after:absolute after:inset-0 [&_svg]:size-3"
|
|
401
|
+
/>
|
|
402
|
+
</div>
|
|
403
|
+
|
|
404
|
+
<div className="border-input has-data-[state=checked]:border-primary/50 relative flex w-full items-center gap-3 rounded-md border p-4 shadow-xs outline-none">
|
|
405
|
+
<img
|
|
406
|
+
className="size-12 rounded-md border p-1"
|
|
407
|
+
src="data:image/svg+xml,%3Csvg%20xmlns%3Ax%3D%22ns_extend%3B%22%20xmlns%3Ai%3D%22ns_ai%3B%22%20xmlns%3Agraph%3D%22ns_graphs%3B%22%20xmlns%3Acc%3D%22http%3A%2F%2Fcreativecommons.org%2Fns%23%22%20xmlns%3Adc%3D%22http%3A%2F%2Fpurl.org%2Fdc%2Felements%2F1.1%2F%22%20xmlns%3Ainkscape%3D%22http%3A%2F%2Fwww.inkscape.org%2Fnamespaces%2Finkscape%22%20xmlns%3Ardf%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2F02%2F22-rdf-syntax-ns%23%22%20xmlns%3Asodipodi%3D%22http%3A%2F%2Fsodipodi.sourceforge.net%2FDTD%2Fsodipodi-0.dtd%22%20xmlns%3Asvg%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Axlink%3D%22http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink%22%20version%3D%221.1%22%20id%3D%22Layer_1%22%20inkscape%3Aversion%3D%221.0.2%20(e86c870879%2C%202021-01-15)%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20262.3%2085%22%20style%3D%22enable-background%3Anew%200%200%20262.3%2085%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20%20.st0%7Bfill%3A%231434CB%3B%7D%20%3C%2Fstyle%3E%3Cmetadata%20id%3D%22metadata3739%22%3E%3Crdf%3ARDF%3E%3Ccc%3AWork%20rdf%3Aabout%3D%22%22%3E%3Cdc%3Aformat%3E%20%20%20%20%20image%2Fsvg%2Bxml%20%20%20%20%3C%2Fdc%3Aformat%3E%3Cdc%3Atype%20rdf%3Aresource%3D%22http%3A%2F%2Fpurl.org%2Fdc%2Fdcmitype%2FStillImage%22%3E%3C%2Fdc%3Atype%3E%3Cdc%3Atitle%3E%3C%2Fdc%3Atitle%3E%3C%2Fcc%3AWork%3E%3C%2Frdf%3ARDF%3E%3Csfw%20xmlns%3D%22ns_sfw%3B%22%3E%3Cslices%3E%3C%2Fslices%3E%3CsliceSourceBounds%20bottomLeftOrigin%3D%22true%22%20height%3D%2285%22%20width%3D%22262.3%22%20x%3D%22737.2%22%20y%3D%220.5%22%3E%3C%2FsliceSourceBounds%3E%3C%2Fsfw%3E%3C%2Fmetadata%3E%3Csodipodi%3Anamedview%20bordercolor%3D%22%23666666%22%20borderopacity%3D%221%22%20fit-margin-bottom%3D%220.5%22%20fit-margin-left%3D%220.5%22%20fit-margin-right%3D%220.5%22%20fit-margin-top%3D%220.5%22%20gridtolerance%3D%2210%22%20guidetolerance%3D%2210%22%20id%3D%22namedview3735%22%20inkscape%3Acurrent-layer%3D%22Layer_1%22%20inkscape%3Acx%3D%22473.80866%22%20inkscape%3Acy%3D%22-26.853447%22%20inkscape%3Adocument-rotation%3D%220%22%20inkscape%3Apageopacity%3D%220%22%20inkscape%3Apageshadow%3D%222%22%20inkscape%3Awindow-height%3D%22705%22%20inkscape%3Awindow-maximized%3D%221%22%20inkscape%3Awindow-width%3D%221366%22%20inkscape%3Awindow-x%3D%22-8%22%20inkscape%3Awindow-y%3D%22-8%22%20inkscape%3Azoom%3D%220.49497088%22%20objecttolerance%3D%2210%22%20pagecolor%3D%22%23ffffff%22%20showgrid%3D%22false%22%3E%3Cinkscape%3Agrid%20empspacing%3D%225%22%20enabled%3D%22true%22%20id%3D%22grid3787%22%20snapvisiblegridlinesonly%3D%22true%22%20type%3D%22xygrid%22%20visible%3D%22true%22%3E%3C%2Finkscape%3Agrid%3E%3C%2Fsodipodi%3Anamedview%3E%3Cpath%20id%3D%22path3789%22%20inkscape%3Aconnector-curvature%3D%220%22%20class%3D%22st0%22%20d%3D%22M170.9%2C0c-18.6%2C0-35.3%2C9.7-35.3%2C27.5%20%20c0%2C20.5%2C29.5%2C21.9%2C29.5%2C32.1c0%2C4.3-5%2C8.2-13.4%2C8.2c-12%2C0-21-5.4-21-5.4l-3.8%2C18c0%2C0%2C10.3%2C4.6%2C24.1%2C4.6c20.4%2C0%2C36.4-10.1%2C36.4-28.3%20%20c0-21.6-29.6-23-29.6-32.5c0-3.4%2C4.1-7.1%2C12.5-7.1c9.5%2C0%2C17.3%2C3.9%2C17.3%2C3.9l3.8-17.4C191.3%2C3.6%2C182.8%2C0%2C170.9%2C0L170.9%2C0z%20M0.5%2C1.3%20%20L0%2C3.9c0%2C0%2C7.8%2C1.4%2C14.9%2C4.3c9.1%2C3.3%2C9.7%2C5.2%2C11.3%2C11.1l16.7%2C64.3h22.4L99.6%2C1.3H77.3l-22.1%2C56l-9-47.5c-0.8-5.4-5-8.5-10.2-8.5%20%20C36%2C1.3%2C0.5%2C1.3%2C0.5%2C1.3z%20M108.6%2C1.3L91.1%2C83.6h21.3l17.4-82.3L108.6%2C1.3L108.6%2C1.3z%20M227.2%2C1.3c-5.1%2C0-7.8%2C2.7-9.8%2C7.5l-31.2%2C74.8%20%20h22.3l4.3-12.5H240l2.6%2C12.5h19.7L245.2%2C1.3L227.2%2C1.3L227.2%2C1.3z%20M230.1%2C23.6l6.6%2C30.9H219L230.1%2C23.6L230.1%2C23.6z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E"
|
|
408
|
+
alt=""
|
|
409
|
+
/>
|
|
410
|
+
<div className="grid grow gap-2">
|
|
411
|
+
<Label
|
|
412
|
+
htmlFor="saved-card-visa"
|
|
413
|
+
className="justify-between"
|
|
414
|
+
>
|
|
415
|
+
Visa
|
|
416
|
+
</Label>
|
|
417
|
+
<p
|
|
418
|
+
id="saved-card-visa-description"
|
|
419
|
+
className="text-muted-foreground text-xs"
|
|
420
|
+
>
|
|
421
|
+
**** **** 2223
|
|
422
|
+
</p>
|
|
423
|
+
</div>
|
|
424
|
+
<RadioGroupItem
|
|
425
|
+
value="visa"
|
|
426
|
+
id="saved-card-visa"
|
|
427
|
+
aria-describedby="saved-card-visa-description"
|
|
428
|
+
className="size-5 after:absolute after:inset-0 [&_svg]:size-3"
|
|
429
|
+
/>
|
|
430
|
+
</div>
|
|
431
|
+
</RadioGroup>
|
|
432
|
+
</div>
|
|
433
|
+
|
|
434
|
+
<div className="flex items-center gap-3">
|
|
435
|
+
<Separator className="flex-1" />
|
|
436
|
+
<span className="text-muted-foreground text-xs">
|
|
437
|
+
or add payment details
|
|
438
|
+
</span>
|
|
439
|
+
<Separator className="flex-1" />
|
|
440
|
+
</div>
|
|
441
|
+
|
|
442
|
+
<div className="space-y-4">
|
|
443
|
+
<Input
|
|
444
|
+
placeholder="0000 0000 0000 0000"
|
|
445
|
+
inputMode="numeric"
|
|
446
|
+
maxLength={19}
|
|
447
|
+
value={cardNumber}
|
|
448
|
+
aria-invalid={Boolean(paymentErrors.cardNumber)}
|
|
449
|
+
onChange={(event) => {
|
|
450
|
+
setCardNumber(formatCardNumber(event.target.value));
|
|
451
|
+
if (paymentErrors.cardNumber) {
|
|
452
|
+
setPaymentErrors((prev) => ({
|
|
453
|
+
...prev,
|
|
454
|
+
cardNumber: undefined,
|
|
455
|
+
}));
|
|
456
|
+
}
|
|
457
|
+
}}
|
|
458
|
+
/>
|
|
459
|
+
<div className="grid grid-cols-2 gap-4">
|
|
460
|
+
<div className="space-y-1">
|
|
461
|
+
<Input
|
|
462
|
+
placeholder="00/00"
|
|
463
|
+
inputMode="numeric"
|
|
464
|
+
maxLength={5}
|
|
465
|
+
value={cardExpiry}
|
|
466
|
+
aria-invalid={Boolean(paymentErrors.cardExpiry)}
|
|
467
|
+
onChange={(event) => {
|
|
468
|
+
setCardExpiry(formatExpiry(event.target.value));
|
|
469
|
+
if (paymentErrors.cardExpiry) {
|
|
470
|
+
setPaymentErrors((prev) => ({
|
|
471
|
+
...prev,
|
|
472
|
+
cardExpiry: undefined,
|
|
473
|
+
}));
|
|
474
|
+
}
|
|
475
|
+
}}
|
|
476
|
+
onBlur={() => {
|
|
477
|
+
setCardExpiry((prev) => normalizeExpiryMonth(prev));
|
|
478
|
+
}}
|
|
479
|
+
/>
|
|
480
|
+
</div>
|
|
481
|
+
<div className="space-y-1">
|
|
482
|
+
<Input
|
|
483
|
+
placeholder="000"
|
|
484
|
+
inputMode="numeric"
|
|
485
|
+
maxLength={4}
|
|
486
|
+
value={cardCvc}
|
|
487
|
+
aria-invalid={Boolean(paymentErrors.cardCvc)}
|
|
488
|
+
onChange={(event) => {
|
|
489
|
+
setCardCvc(
|
|
490
|
+
event.target.value.replace(/\D/g, "").slice(0, 3),
|
|
491
|
+
);
|
|
492
|
+
if (paymentErrors.cardCvc) {
|
|
493
|
+
setPaymentErrors((prev) => ({
|
|
494
|
+
...prev,
|
|
495
|
+
cardCvc: undefined,
|
|
496
|
+
}));
|
|
497
|
+
}
|
|
498
|
+
}}
|
|
499
|
+
/>
|
|
500
|
+
</div>
|
|
501
|
+
</div>
|
|
502
|
+
</div>
|
|
503
|
+
|
|
504
|
+
<Button className="w-full" size="lg" type="submit">
|
|
505
|
+
Pay Now
|
|
506
|
+
</Button>
|
|
507
|
+
|
|
508
|
+
<p className="text-muted-foreground flex items-center justify-center gap-1 text-xs">
|
|
509
|
+
<Shield className="size-4 text-emerald-500" />
|
|
510
|
+
Protected with Secure Payment by Payme.
|
|
511
|
+
<a href="#" type="button" className="text-foreground underline">
|
|
512
|
+
Learn More
|
|
513
|
+
</a>
|
|
514
|
+
</p>
|
|
515
|
+
</form>
|
|
516
|
+
</DialogContent>
|
|
517
|
+
</Dialog>
|
|
518
|
+
</section>
|
|
519
|
+
);
|
|
520
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function(shared, config) { return config }
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import Image from "next/image";
|
|
4
|
+
import Link from "next/link";
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
Breadcrumb,
|
|
8
|
+
BreadcrumbItem,
|
|
9
|
+
BreadcrumbLink,
|
|
10
|
+
BreadcrumbList,
|
|
11
|
+
BreadcrumbPage,
|
|
12
|
+
BreadcrumbSeparator,
|
|
13
|
+
} from "@/components/ui/breadcrumb";
|
|
14
|
+
import {
|
|
15
|
+
Carousel,
|
|
16
|
+
CarouselContent,
|
|
17
|
+
CarouselItem,
|
|
18
|
+
CarouselNext,
|
|
19
|
+
CarouselPrevious,
|
|
20
|
+
} from "@/components/ui/carousel";
|
|
21
|
+
import { Card } from "@/components/ui/card";
|
|
22
|
+
|
|
23
|
+
const categories = [
|
|
24
|
+
{
|
|
25
|
+
name: "Handbags",
|
|
26
|
+
href: "#",
|
|
27
|
+
imageSrc:
|
|
28
|
+
"https://images.unsplash.com/photo-1594221708779-94832f4320d1?w=400&q=80",
|
|
29
|
+
imageAlt: "Handbags category",
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
name: "Jewellery",
|
|
33
|
+
href: "#",
|
|
34
|
+
imageSrc:
|
|
35
|
+
"https://images.unsplash.com/photo-1515562141207-7a88fb7ce338?w=400&q=80",
|
|
36
|
+
imageAlt: "Jewellery category",
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
name: "GUCCI",
|
|
40
|
+
href: "#",
|
|
41
|
+
imageSrc:
|
|
42
|
+
"https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?w=400&q=80",
|
|
43
|
+
imageAlt: "GUCCI brand",
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
name: "Fragrance",
|
|
47
|
+
href: "#",
|
|
48
|
+
imageSrc:
|
|
49
|
+
"https://images.unsplash.com/photo-1541643600914-78b084683601?w=400&q=80",
|
|
50
|
+
imageAlt: "Fragrance category",
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
name: "Lamps",
|
|
54
|
+
href: "#",
|
|
55
|
+
imageSrc:
|
|
56
|
+
"https://images.unsplash.com/photo-1487070183336-b863922373d4?w=400&q=80",
|
|
57
|
+
imageAlt: "Lamps category",
|
|
58
|
+
},
|
|
59
|
+
] as const;
|
|
60
|
+
|
|
61
|
+
export default function ProductCategory() {
|
|
62
|
+
return (
|
|
63
|
+
<section className="py-14 md:py-16">
|
|
64
|
+
<div className="mx-auto max-w-7xl px-4">
|
|
65
|
+
<Breadcrumb className="mb-4">
|
|
66
|
+
<BreadcrumbList>
|
|
67
|
+
<BreadcrumbItem>
|
|
68
|
+
<BreadcrumbLink asChild>
|
|
69
|
+
<Link href="#">Home</Link>
|
|
70
|
+
</BreadcrumbLink>
|
|
71
|
+
</BreadcrumbItem>
|
|
72
|
+
<BreadcrumbSeparator />
|
|
73
|
+
<BreadcrumbItem>
|
|
74
|
+
<BreadcrumbPage>Collection</BreadcrumbPage>
|
|
75
|
+
</BreadcrumbItem>
|
|
76
|
+
</BreadcrumbList>
|
|
77
|
+
</Breadcrumb>
|
|
78
|
+
|
|
79
|
+
<Carousel
|
|
80
|
+
opts={{
|
|
81
|
+
align: "start",
|
|
82
|
+
dragFree: true,
|
|
83
|
+
containScroll: "trimSnaps",
|
|
84
|
+
}}
|
|
85
|
+
>
|
|
86
|
+
<div className="mb-8 flex items-center justify-between">
|
|
87
|
+
<h1 className="text-3xl font-bold md:text-4xl">All Product</h1>
|
|
88
|
+
<div className="flex gap-2">
|
|
89
|
+
<CarouselPrevious className="relative top-0 left-0 translate-x-0 translate-y-0" />
|
|
90
|
+
<CarouselNext className="relative top-0 right-0 translate-x-0 translate-y-0" />
|
|
91
|
+
</div>
|
|
92
|
+
</div>
|
|
93
|
+
<CarouselContent>
|
|
94
|
+
{categories.map((category) => (
|
|
95
|
+
<CarouselItem
|
|
96
|
+
key={category.name}
|
|
97
|
+
className="min-w-0 basis-[calc((100%-3rem)/4)] pl-4"
|
|
98
|
+
>
|
|
99
|
+
<Card className="overflow-hidden rounded-none border-0 p-0 shadow-none">
|
|
100
|
+
<Link href={category.href} className="block">
|
|
101
|
+
<div className="aspect-3/4 overflow-hidden">
|
|
102
|
+
<Image
|
|
103
|
+
src={category.imageSrc}
|
|
104
|
+
alt={category.imageAlt}
|
|
105
|
+
width={240}
|
|
106
|
+
height={320}
|
|
107
|
+
className="h-full w-full rounded-lg object-cover"
|
|
108
|
+
unoptimized
|
|
109
|
+
/>
|
|
110
|
+
</div>
|
|
111
|
+
<p className="p-4 text-center">{category.name}</p>
|
|
112
|
+
</Link>
|
|
113
|
+
</Card>
|
|
114
|
+
</CarouselItem>
|
|
115
|
+
))}
|
|
116
|
+
</CarouselContent>
|
|
117
|
+
</Carousel>
|
|
118
|
+
</div>
|
|
119
|
+
</section>
|
|
120
|
+
);
|
|
121
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function(shared, config) { return config }
|