lunar
lunar copied to clipboard
Feat - Discounts
This is an initial PR to get discounts started in the core...
The latest updates on your projects. Learn more about Vercel for Git ↗︎
Name | Status | Preview | Updated |
---|---|---|---|
getcandy-2-docs | ✅ Ready (Inspect) | Visit Preview | Dec 13, 2022 at 1:48PM (UTC) |
lunar-docs | ✅ Ready (Inspect) | Visit Preview | Dec 13, 2022 at 1:48PM (UTC) |
I've had a quick look through this and it all looks promising so far. One use case that we would have would be setting an entire brand
or category
on discount... from what I'm seeing that would mean adding every purchasable in those brands, which could be unwieldy. Would it be an option to change how you work out what items the discount applies to, so that a developer can write some custom logic to determine that?
I've had a quick look through this and it all looks promising so far. One use case that we would have would be setting an entire
brand
orcategory
on discount... from what I'm seeing that would mean adding every purchasable in those brands, which could be unwieldy. Would it be an option to change how you work out what items the discount applies to, so that a developer can write some custom logic to determine that?
We did intend to allow Collections to be added also. As for Brands, I guess it could be possible, but we're just trying to get an MVP out there. You can make your own discount types if you need something specific.
Looks good, but I found a few issues/concerns.
- When saving a discount it flashes the notification but immediately refreshes the page.
- Errors at the top of the form are not clear when trying to save a discount.
Few points here.
- Why is the "Priority" input so big?
- We need an explanation of what "Priority" is. It's not obvious, especially for non-developers.
- It would be helpful to have a way to view the current priority list.
- "Stop" is misleading. It looks like it will stop the discount.
- The word "propagating" is confusing, it needs a non-developer explanation. Something like...
Checking this will prevent other discounts from being applied if the current discount criteria is matched.
The UI is a little wonky here. It looks like some classes are missing on the parent, possibly p-2 space-y-2
.
- Show which discounts are active based on the date.
- Add sorting for date and status (active/inactive/scheduled).
- I don't think "Stop" is needed.
Adding a "Select All" could be handy, especially if there are lots of collections/brands.
The active button is invisible.
More of a generic issue across the hub, but the error icon overlaps the spinners in the number input.
Feedback...
We want to split the edit screen into 3 sections. The general information, e.g. name, handle, discount type, etc. Then the conditions for the discount, and then finally the rewards. We should break it up into separate panes to indicate this, as it's quite a full-on form currently.
Coupons should be part of the generic conditions for a discount. A discount should either automatically apply or be applied by a matching coupon.
Discount types should be "Buy X Get Y" or "Discount".
Buy X Get Y
This is the typical BOGOF type promotion. You can state which products you need to buy to qualify, and state which products you can get for free. We need to update the Cart to list the available free products (I did something before on a previous PR we closed). The free products should be grouped by the qualifying discount so that customers can easily apply them to their cart. If a customer already has a qualifying product in their cart, then they get it for free. If they remove it or don't apply a free product, then they simply won't get it.
Discount
This gives a % off the cart if the conditions are met. It may only discount certain products in the cart, or all products in the cart. We currently allow for a fixed amount off, if we're doing that it will need to be multi-currency. We also need to be careful that fixed amounts don't make something too cheap, free or even a negative amount. I guess there is an onus on the store owner to ensure the logic is correct, but we certainly should never have a negative number.
Misc. Feedback
The "min. cart amount" field is far too wide and it should also default to "0". In fact, there are a LOT of very wide inputs, which makes it hard to see what is expected.
E.g.
There are no conditions for channels and customer groups, we'll need those.
Do we need to consider reporting on how many times a discount has been used?
hello , I found an error in this branch ... it happens when I perform a clean install
error: "Foreign key constraint is incorrectly formed"
explanation: the error happens because the "brand_discount" table asks for a primary key "brand_id" that does not yet exist
how I fixed: simply renamed the "brand_discount" migration to migrate after the "brands"
@glennjacobs I've pushed a bunch of updates to the UI. Hopefully you should be able to pull down without any issue, but if there are problems let me know. it's a WIP atm.
Generally a great improvement. Here are my thoughts...
data:image/s3,"s3://crabby-images/ad3f9/ad3f99187b011cd8f38599f4416bdecf94948a82" alt="image"
data:image/s3,"s3://crabby-images/55fb7/55fb74acb65512e77c1985b1cc2a5c6ad1269cf1" alt="image"
I think inputs should always have default values where possible.
data:image/s3,"s3://crabby-images/d94e9/d94e9f0e034a14558e093e8c5d4ea0f58f8c6f76" alt="image"
Collections are not grouped by "Collection Group", might get a little confusing.
data:image/s3,"s3://crabby-images/b83c8/b83c83f3a62ac698e3c2048fc4514b47cfd6d974" alt="image"
data:image/s3,"s3://crabby-images/ef051/ef051e27cd33db983053cae7fdaa2d50ef3f8539" alt="image"
@alecritson
the migration error still exists
but now because of the "discounts" table
to fix it I renamed the discounts migration 2022_11_18_100000_create_discounts_table.php
to 2022_06_16_100000_create_discounts_table.php
a suggestion....
I believe that when there are several registered brands or collections, it can end up creating a rather large scroll, making it difficult for the end user
make this
more like this:
data:image/s3,"s3://crabby-images/78647/78647defc0b50a854859364a7145b26153a3e56c" alt="image"
data:image/s3,"s3://crabby-images/11a2d/11a2de6696b0e18374a1f09a7a4e13806b83652b" alt="image"
data:image/s3,"s3://crabby-images/dddf8/dddf8804e95963423d1d703c05e83aab105d74f6" alt="image"
data:image/s3,"s3://crabby-images/b6d8a/b6d8a1f3a47d70e4015adb4668e78b26890a1311" alt="image"
data:image/s3,"s3://crabby-images/12aab/12aab691554d2e195cf7a64b456f8a7ecf5c3e53" alt="image"
data:image/s3,"s3://crabby-images/412a1/412a1ad88d2f0d30dcc508b61cdfb044ef7d3247" alt="image"
data:image/s3,"s3://crabby-images/32a8c/32a8c871c95c95ae26a4b8e759b50ac6e78d5349" alt="image"
Validation doesn't show what's missing/wrong. E.g. not adding any Qualifying Products.
data:image/s3,"s3://crabby-images/13f47/13f4712e57f86d0cf622282ce15922c1f2d3d549" alt="image"
Can it be
"Qualifying Products"
"Product Rewards"
?
data:image/s3,"s3://crabby-images/99eb6/99eb6ed0d1d1a2108c6c0d46fdc1723d6c791d92" alt="image"
Setting max uses and then unsetting it causes this error.
data:image/s3,"s3://crabby-images/e30ea/e30ea876326e1bc43205ac4b93ac923562206b0d" alt="image"
data:image/s3,"s3://crabby-images/3fe80/3fe80eb141e7447c48c12b5b2be19bced81a1381" alt="image"
data:image/s3,"s3://crabby-images/377be/377be20024df4cfff3ba3e504480834bd9f5cc42" alt="image"
No validation error if no products are selected on a "Buy X Get Y" discount type.
Validation errors display in the Discount Type pane, but the menu on the right doesn't indicate this by showing the menu item in red.
data:image/s3,"s3://crabby-images/61943/6194333aa37b2d58bb4bbaa3ef45b640f9cf9cd7" alt="image"
No validation on "Percentage" or "Fixed Amount" inputs.
data:image/s3,"s3://crabby-images/1289c/1289cff8733f1260bce2589df030f3bb18638180" alt="image"
Can we use the titles
"Qualify Products" & "Product Rewards"
?
How about showing the discount type on the index datatable?