forked from solidusio/solidus
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Admin stock items: Load modal with turbo frame
- Loading branch information
Showing
4 changed files
with
100 additions
and
108 deletions.
There are no files selected for viewing
147 changes: 74 additions & 73 deletions
147
admin/app/components/solidus_admin/stock_items/edit/component.html.erb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,83 +1,84 @@ | ||
<div | ||
data-controller="<%= stimulus_id %>" | ||
data-<%= stimulus_id %>-initial-count-on-hand-value="<%= @stock_item.count_on_hand_was || @stock_item.count_on_hand %>" | ||
data-action="input-><%= stimulus_id %>#updateCountOnHand" | ||
> | ||
<%= turbo_frame_tag :edit_stock_item_modal do %> | ||
<%= render component("ui/modal").new(title: t(".title")) do |modal| %> | ||
<%= form_for @stock_item, url: solidus_admin.stock_item_path(@stock_item), html: { id: form_id } do |f| %> | ||
<div class="flex flex-col gap-6 pb-4"> | ||
<div class="flex gap-4"> | ||
<%= link_to spree.edit_admin_product_variant_path( | ||
@stock_item.variant.product, | ||
@stock_item.variant, | ||
), class: 'hover:bg-gray-25 rounded p-1 w-1/2 border border-gray-100' do %> | ||
<%= render component("ui/resource_item").new( | ||
thumbnail: | ||
( | ||
@stock_item.variant.images.first || | ||
@stock_item.variant.product.gallery.images.first | ||
)&.url(:small), | ||
title: @stock_item.variant.name, | ||
subtitle: | ||
"#{@stock_item.variant.sku}#{@stock_item.variant.options_text.presence&.prepend(" - ")}", | ||
) %> | ||
<% end %> | ||
<%= link_to spree.edit_admin_stock_location_path(@stock_item.stock_location), class: 'hover:bg-gray-25 rounded p-1 w-1/2 border border-gray-100' do %> | ||
<%= render component("ui/resource_item").new( | ||
title: @stock_item.stock_location.name, | ||
subtitle: "#{Spree::StockLocation.model_name.human} #{@stock_item.stock_location.code}", | ||
) %> | ||
<% end %> | ||
</div> | ||
|
||
<%= render component("ui/forms/field").text_field( | ||
f, | ||
:count_on_hand, | ||
disabled: true, | ||
value: @stock_item.count_on_hand_was || @stock_item.count_on_hand, | ||
"data-#{stimulus_id}-target": 'countOnHand', | ||
) %> | ||
<%= render component("ui/forms/field").new( | ||
label: t(".quantity_adjustment"), | ||
hint: t(".quantity_adjustment_hint_html"), | ||
) do %> | ||
<%= render component("ui/forms/input").new( | ||
value: params[:quantity_adjustment] || 0, | ||
name: :quantity_adjustment, | ||
type: :number, | ||
step: 1, | ||
"data-#{stimulus_id}-target": 'quantityAdjustment', | ||
<%= turbo_frame_tag :resource_modal, target: "_top" do %> | ||
<%= render component("ui/modal").new(title: t(".title")) do |modal| %> | ||
<%= form_for @stock_item, url: form_url, html: { id: form_id } do |f| %> | ||
<div | ||
class="flex flex-col gap-6 pb-4" | ||
data-controller="<%= stimulus_id %>" | ||
data-<%= stimulus_id %>-initial-count-on-hand-value="<%= @stock_item.count_on_hand_was || @stock_item.count_on_hand %>" | ||
data-action="input-><%= stimulus_id %>#updateCountOnHand" | ||
> | ||
<div class="flex gap-4"> | ||
<%= link_to spree.edit_admin_product_variant_path( | ||
@stock_item.variant.product, | ||
@stock_item.variant, | ||
), | ||
data: {turbo_frame: "_top"}, | ||
class: 'hover:bg-gray-25 rounded p-1 w-1/2 border border-gray-100' do %> | ||
<%= render component("ui/resource_item").new( | ||
thumbnail: | ||
( | ||
@stock_item.variant.images.first || | ||
@stock_item.variant.product.gallery.images.first | ||
)&.url(:small), | ||
title: @stock_item.variant.name, | ||
subtitle: | ||
"#{@stock_item.variant.sku}#{@stock_item.variant.options_text.presence&.prepend(" - ")}", | ||
) %> | ||
<% end %> | ||
<%= link_to spree.edit_admin_stock_location_path(@stock_item.stock_location), | ||
data: {turbo_frame: "_top"}, | ||
class: 'hover:bg-gray-25 rounded p-1 w-1/2 border border-gray-100' do %> | ||
<%= render component("ui/resource_item").new( | ||
title: @stock_item.stock_location.name, | ||
subtitle: "#{Spree::StockLocation.model_name.human} #{@stock_item.stock_location.code}", | ||
) %> | ||
<% end %> | ||
|
||
<%= render component("ui/forms/switch_field").new( | ||
name: "#{f.object_name}[backorderable]", | ||
label: Spree::StockItem.human_attribute_name(:backorderable), | ||
error: f.object.errors[:backorderable], | ||
hint: t(".backorderable_hint_html"), | ||
checked: f.object.backorderable?, | ||
include_hidden: true, | ||
) %> | ||
</div> | ||
<% end %> | ||
|
||
<% modal.with_actions do %> | ||
<form method="dialog"> | ||
<%= render component("ui/button").new( | ||
scheme: :secondary, | ||
text: t(".cancel"), | ||
<%= render component("ui/forms/field").text_field( | ||
f, | ||
:count_on_hand, | ||
readonly: true, | ||
value: @stock_item.count_on_hand_was || @stock_item.count_on_hand, | ||
"data-#{stimulus_id}-target": 'countOnHand', | ||
) %> | ||
<%= render component("ui/forms/field").new( | ||
label: t(".quantity_adjustment"), | ||
hint: t(".quantity_adjustment_hint_html"), | ||
) do %> | ||
<%= render component("ui/forms/input").new( | ||
value: params[:quantity_adjustment] || 0, | ||
name: :quantity_adjustment, | ||
type: :number, | ||
step: 1, | ||
"data-#{stimulus_id}-target": 'quantityAdjustment', | ||
) %> | ||
</form> | ||
<% end %> | ||
|
||
<%= render component("ui/forms/switch_field").new( | ||
name: "#{f.object_name}[backorderable]", | ||
label: Spree::StockItem.human_attribute_name(:backorderable), | ||
error: f.object.errors[:backorderable], | ||
hint: t(".backorderable_hint_html"), | ||
checked: f.object.backorderable?, | ||
include_hidden: true, | ||
) %> | ||
</div> | ||
<% end %> | ||
|
||
<% modal.with_actions do %> | ||
<form method="dialog"> | ||
<%= render component("ui/button").new( | ||
tag: :button, | ||
text: t(".submit"), | ||
form: form_id, | ||
scheme: :secondary, | ||
text: t(".cancel"), | ||
) %> | ||
<% end %> | ||
</form> | ||
|
||
<%= render component("ui/button").new( | ||
tag: :button, | ||
text: t(".submit"), | ||
form: form_id, | ||
) %> | ||
<% end %> | ||
<% end %> | ||
|
||
<%= render component("stock_items/index").new(page: @page) %> | ||
</div> | ||
<% end %> |
11 changes: 1 addition & 10 deletions
11
admin/app/components/solidus_admin/stock_items/edit/component.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,18 +1,9 @@ | ||
# frozen_string_literal: true | ||
|
||
class SolidusAdmin::StockItems::Edit::Component < SolidusAdmin::BaseComponent | ||
def initialize(stock_item:, page:) | ||
@stock_item = stock_item | ||
@page = page | ||
end | ||
|
||
class SolidusAdmin::StockItems::Edit::Component < SolidusAdmin::Resources::Edit::Component | ||
def title | ||
[ | ||
"#{Spree::StockLocation.model_name.human}: #{@stock_item.stock_location.name}", | ||
].join(' / ') | ||
end | ||
|
||
def form_id | ||
"#{stimulus_id}-#{dom_id(@stock_item)}" | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters