-
Notifications
You must be signed in to change notification settings - Fork 153
Add Storefront properties for Product Attributes #490
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
# Copyright © Magento, Inc. All rights reserved. | ||
# See COPYING.txt for license details. | ||
|
||
type Query { | ||
customAttributeMetadata(attributes: [AttributeInput!]!): CustomAttributeMetadata @resolver(class: "Magento\\EavGraphQl\\Model\\Resolver\\CustomAttributeMetadata") @doc(description: "The customAttributeMetadata query returns the attribute type, given an attribute code and entity type") @cache(cacheable: false) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this is good but please change the location of your file to this file |
||
} | ||
|
||
type CustomAttributeMetadata @doc(description: "CustomAttributeMetadata defines an array of attribute_codes and entity_types") { | ||
items: [Attribute] @doc(description: "An array of attributes") | ||
} | ||
|
||
type Attribute @doc(description: "Attribute contains the attribute_type of the specified attribute_code and entity_type") { | ||
attribute_code: String @doc(description: "The unique identifier for an attribute code. This value should be in lowercase letters without spaces.") | ||
entity_type: String @doc(description: "The type of entity that defines the attribute") | ||
attribute_type: String @doc(description: "The data type of the attribute") | ||
input_type: String @doc(description: "The frontend input type of the attribute") | ||
attribute_options: [AttributeOption] @resolver(class: "Magento\\EavGraphQl\\Model\\Resolver\\AttributeOptions") @doc(description: "Attribute options list.") | ||
storefront_properties: StorefrontProperties | ||
} | ||
|
||
type StorefrontProperties { | ||
used_in_product_listing: Boolean | ||
position: Int | ||
visible_on_catalog_storefront: Boolean | ||
use_in_layered_navigation: UseInLayeredNavigationOptions | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Perhaps name these There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I understand these names come directly from the backend. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, the idea was to reflect the same configuration names as in the backend. So there will be consistency in dev docs too. @keharper can help with the naming. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm in favor of changing There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Okay. I will update it. Thanks! |
||
use_in_search_results_layered_navigation: Boolean | ||
use_in_search: Boolean | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think this needs to be included. The way I understand it, this is more for y'all or the search team. If Venia won't do anything with this setting. |
||
} | ||
|
||
enum UseInLayeredNavigationOptions { | ||
NO | ||
FILTERABLE_WITH_RESULTS | ||
FILTERABLE_NO_RESULT | ||
} | ||
|
||
type AttributeOption @doc(description: "Attribute option.") { | ||
label: String @doc(description: "Attribute option label.") | ||
value: String @doc(description: "Attribute option value.") | ||
} | ||
|
||
input AttributeInput @doc(description: "AttributeInput specifies the attribute_code and entity_type to search") { | ||
attribute_code: String @doc(description: "The unique identifier for an attribute code. This value should be in lowercase letters without spaces.") | ||
entity_type: String @doc(description: "The type of entity that defines the attribute") | ||
} | ||
|
||
# Additional changes made in CatalogGraphQl schema | ||
type Aggregation @doc(description: "A bucket that contains information for each filterable option (such as price, category `UID`, and custom attributes).") { | ||
position: Int @doc(description: "The position of attribute in layered navigation block.") | ||
} |
Uh oh!
There was an error while loading. Please reload this page.