polaris_view_components 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/LICENSE.txt +20 -0
- data/README.md +51 -0
- data/app/assets/icons/polaris/AbandonedCartMajor.svg +1 -0
- data/app/assets/icons/polaris/AccessibilityMajor.svg +1 -0
- data/app/assets/icons/polaris/ActivitiesMajor.svg +1 -0
- data/app/assets/icons/polaris/AddCodeMajor.svg +1 -0
- data/app/assets/icons/polaris/AddImageMajor.svg +1 -0
- data/app/assets/icons/polaris/AddMajor.svg +1 -0
- data/app/assets/icons/polaris/AddNoteMajor.svg +1 -0
- data/app/assets/icons/polaris/AddProductMajor.svg +1 -0
- data/app/assets/icons/polaris/AffiliateMajor.svg +1 -0
- data/app/assets/icons/polaris/AlertMinor.svg +1 -0
- data/app/assets/icons/polaris/AnalyticsMajor.svg +1 -0
- data/app/assets/icons/polaris/AppExtensionMinor.svg +1 -0
- data/app/assets/icons/polaris/AppsMajor.svg +1 -0
- data/app/assets/icons/polaris/ArchiveMajor.svg +1 -0
- data/app/assets/icons/polaris/ArchiveMinor.svg +1 -0
- data/app/assets/icons/polaris/ArrowDownMinor.svg +1 -0
- data/app/assets/icons/polaris/ArrowLeftMinor.svg +1 -0
- data/app/assets/icons/polaris/ArrowRightMinor.svg +1 -0
- data/app/assets/icons/polaris/ArrowUpMinor.svg +1 -0
- data/app/assets/icons/polaris/AttachmentMajor.svg +1 -0
- data/app/assets/icons/polaris/AutomationMajor.svg +1 -0
- data/app/assets/icons/polaris/BackspaceMajor.svg +1 -0
- data/app/assets/icons/polaris/BalanceMajor.svg +1 -0
- data/app/assets/icons/polaris/BankMajor.svg +1 -0
- data/app/assets/icons/polaris/BarcodeMajor.svg +1 -0
- data/app/assets/icons/polaris/BehaviorMajor.svg +1 -0
- data/app/assets/icons/polaris/BillingStatementDollarMajor.svg +1 -0
- data/app/assets/icons/polaris/BillingStatementEuroMajor.svg +1 -0
- data/app/assets/icons/polaris/BillingStatementPoundMajor.svg +1 -0
- data/app/assets/icons/polaris/BillingStatementRupeeMajor.svg +1 -0
- data/app/assets/icons/polaris/BillingStatementYenMajor.svg +1 -0
- data/app/assets/icons/polaris/BlockquoteMajor.svg +1 -0
- data/app/assets/icons/polaris/BlogMajor.svg +1 -0
- data/app/assets/icons/polaris/BugMajor.svg +1 -0
- data/app/assets/icons/polaris/ButtonCornerPillMajor.svg +1 -0
- data/app/assets/icons/polaris/ButtonCornerRoundedMajor.svg +1 -0
- data/app/assets/icons/polaris/ButtonCornerSquareMajor.svg +1 -0
- data/app/assets/icons/polaris/BuyButtonButtonLayoutMajor.svg +1 -0
- data/app/assets/icons/polaris/BuyButtonHorizontalLayoutMajor.svg +1 -0
- data/app/assets/icons/polaris/BuyButtonMajor.svg +1 -0
- data/app/assets/icons/polaris/BuyButtonVerticalLayoutMajor.svg +1 -0
- data/app/assets/icons/polaris/CalendarMajor.svg +1 -0
- data/app/assets/icons/polaris/CalendarMinor.svg +1 -0
- data/app/assets/icons/polaris/CalendarTickMajor.svg +1 -0
- data/app/assets/icons/polaris/CameraMajor.svg +1 -0
- data/app/assets/icons/polaris/CancelSmallMinor.svg +1 -0
- data/app/assets/icons/polaris/CapitalMajor.svg +1 -0
- data/app/assets/icons/polaris/CapturePaymentMinor.svg +1 -0
- data/app/assets/icons/polaris/CardReaderChipMajor.svg +1 -0
- data/app/assets/icons/polaris/CardReaderMajor.svg +1 -0
- data/app/assets/icons/polaris/CardReaderTapMajor.svg +1 -0
- data/app/assets/icons/polaris/CaretDownMinor.svg +1 -0
- data/app/assets/icons/polaris/CaretUpMinor.svg +1 -0
- data/app/assets/icons/polaris/CartDownMajor.svg +1 -0
- data/app/assets/icons/polaris/CartMajor.svg +1 -0
- data/app/assets/icons/polaris/CartUpMajor.svg +1 -0
- data/app/assets/icons/polaris/CashDollarMajor.svg +1 -0
- data/app/assets/icons/polaris/CashEuroMajor.svg +1 -0
- data/app/assets/icons/polaris/CashPoundMajor.svg +1 -0
- data/app/assets/icons/polaris/CashRupeeMajor.svg +1 -0
- data/app/assets/icons/polaris/CashYenMajor.svg +1 -0
- data/app/assets/icons/polaris/CategoriesMajor.svg +1 -0
- data/app/assets/icons/polaris/ChannelsMajor.svg +1 -0
- data/app/assets/icons/polaris/ChatMajor.svg +1 -0
- data/app/assets/icons/polaris/ChecklistAlternateMajor.svg +1 -0
- data/app/assets/icons/polaris/ChecklistMajor.svg +1 -0
- data/app/assets/icons/polaris/CheckoutMajor.svg +1 -0
- data/app/assets/icons/polaris/ChevronDownMinor.svg +1 -0
- data/app/assets/icons/polaris/ChevronLeftMinor.svg +1 -0
- data/app/assets/icons/polaris/ChevronRightMinor.svg +1 -0
- data/app/assets/icons/polaris/ChevronUpMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleAlertMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleCancelMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleCancelMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleChevronDownMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleChevronLeftMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleChevronRightMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleChevronUpMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleDisableMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleDisabledMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleDotsMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleDownMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleInformationMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleLeftMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleMinusMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleMinusMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleMinusOutlineMinor.svg +1 -0
- data/app/assets/icons/polaris/CirclePlusMajor.svg +1 -0
- data/app/assets/icons/polaris/CirclePlusMinor.svg +1 -0
- data/app/assets/icons/polaris/CirclePlusOutlineMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleRightMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleTickMajor.svg +1 -0
- data/app/assets/icons/polaris/CircleTickOutlineMinor.svg +1 -0
- data/app/assets/icons/polaris/CircleUpMajor.svg +1 -0
- data/app/assets/icons/polaris/ClipboardMinor.svg +1 -0
- data/app/assets/icons/polaris/ClockMajor.svg +1 -0
- data/app/assets/icons/polaris/ClockMinor.svg +1 -0
- data/app/assets/icons/polaris/CodeMajor.svg +1 -0
- data/app/assets/icons/polaris/CollectionsMajor.svg +1 -0
- data/app/assets/icons/polaris/ColorNoneMinor.svg +1 -0
- data/app/assets/icons/polaris/ColorsMajor.svg +1 -0
- data/app/assets/icons/polaris/Column1Major.svg +1 -0
- data/app/assets/icons/polaris/ColumnWithTextMajor.svg +1 -0
- data/app/assets/icons/polaris/Columns2Major.svg +1 -0
- data/app/assets/icons/polaris/Columns3Major.svg +1 -0
- data/app/assets/icons/polaris/ComposeMajor.svg +1 -0
- data/app/assets/icons/polaris/ConfettiMajor.svg +1 -0
- data/app/assets/icons/polaris/ConnectMinor.svg +1 -0
- data/app/assets/icons/polaris/ConversationMinor.svg +1 -0
- data/app/assets/icons/polaris/CreditCardMajor.svg +1 -0
- data/app/assets/icons/polaris/CreditCardPercentMajor.svg +1 -0
- data/app/assets/icons/polaris/CreditCardSecureMajor.svg +1 -0
- data/app/assets/icons/polaris/CurrencyConvertMinor.svg +1 -0
- data/app/assets/icons/polaris/CustomerMinusMajor.svg +1 -0
- data/app/assets/icons/polaris/CustomerPlusMajor.svg +1 -0
- data/app/assets/icons/polaris/CustomersMajor.svg +1 -0
- data/app/assets/icons/polaris/CustomersMinor.svg +1 -0
- data/app/assets/icons/polaris/DataVisualizationMajor.svg +1 -0
- data/app/assets/icons/polaris/DeleteMajor.svg +1 -0
- data/app/assets/icons/polaris/DeleteMinor.svg +1 -0
- data/app/assets/icons/polaris/DesktopMajor.svg +1 -0
- data/app/assets/icons/polaris/DetailedPopUpMajor.svg +1 -0
- data/app/assets/icons/polaris/DiamondAlertMajor.svg +1 -0
- data/app/assets/icons/polaris/DigitalMediaReceiverMajor.svg +1 -0
- data/app/assets/icons/polaris/DiscountAutomaticMajor.svg +1 -0
- data/app/assets/icons/polaris/DiscountCodeMajor.svg +1 -0
- data/app/assets/icons/polaris/DiscountsMajor.svg +1 -0
- data/app/assets/icons/polaris/DisputeMinor.svg +1 -0
- data/app/assets/icons/polaris/DnsSettingsMajor.svg +1 -0
- data/app/assets/icons/polaris/DomainNewMajor.svg +1 -0
- data/app/assets/icons/polaris/DomainsMajor.svg +1 -0
- data/app/assets/icons/polaris/DraftOrdersMajor.svg +1 -0
- data/app/assets/icons/polaris/DragDropMajor.svg +1 -0
- data/app/assets/icons/polaris/DragHandleMinor.svg +1 -0
- data/app/assets/icons/polaris/DropdownMinor.svg +1 -0
- data/app/assets/icons/polaris/DuplicateMinor.svg +1 -0
- data/app/assets/icons/polaris/EditMajor.svg +1 -0
- data/app/assets/icons/polaris/EditMinor.svg +1 -0
- data/app/assets/icons/polaris/EmailMajor.svg +1 -0
- data/app/assets/icons/polaris/EmailNewsletterMajor.svg +1 -0
- data/app/assets/icons/polaris/EmbedMinor.svg +1 -0
- data/app/assets/icons/polaris/EnableSelectionMinor.svg +1 -0
- data/app/assets/icons/polaris/EnvelopeMajor.svg +1 -0
- data/app/assets/icons/polaris/ExchangeMajor.svg +1 -0
- data/app/assets/icons/polaris/ExistingInventoryMajor.svg +1 -0
- data/app/assets/icons/polaris/ExitMajor.svg +1 -0
- data/app/assets/icons/polaris/ExportMinor.svg +1 -0
- data/app/assets/icons/polaris/ExternalMinor.svg +1 -0
- data/app/assets/icons/polaris/ExternalSmallMinor.svg +1 -0
- data/app/assets/icons/polaris/FaviconMajor.svg +1 -0
- data/app/assets/icons/polaris/FavoriteMajor.svg +1 -0
- data/app/assets/icons/polaris/FeaturedCollectionMajor.svg +1 -0
- data/app/assets/icons/polaris/FeaturedContentMajor.svg +1 -0
- data/app/assets/icons/polaris/FilterMajor.svg +1 -0
- data/app/assets/icons/polaris/FirstOrderMajor.svg +1 -0
- data/app/assets/icons/polaris/FirstVisitMajor.svg +1 -0
- data/app/assets/icons/polaris/FlagMajor.svg +1 -0
- data/app/assets/icons/polaris/FlipCameraMajor.svg +1 -0
- data/app/assets/icons/polaris/FolderDownMajor.svg +1 -0
- data/app/assets/icons/polaris/FolderMajor.svg +1 -0
- data/app/assets/icons/polaris/FolderMinusMajor.svg +1 -0
- data/app/assets/icons/polaris/FolderPlusMajor.svg +1 -0
- data/app/assets/icons/polaris/FolderUpMajor.svg +1 -0
- data/app/assets/icons/polaris/FollowUpEmailMajor.svg +1 -0
- data/app/assets/icons/polaris/FoodMajor.svg +1 -0
- data/app/assets/icons/polaris/FooterMajor.svg +1 -0
- data/app/assets/icons/polaris/FormsMajor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectMajor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectMinor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectPendingMajor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectPendingMinor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectUnprotectedMajor.svg +1 -0
- data/app/assets/icons/polaris/FraudProtectUnprotectedMinor.svg +1 -0
- data/app/assets/icons/polaris/GamesConsoleMajor.svg +1 -0
- data/app/assets/icons/polaris/GiftCardMajor.svg +1 -0
- data/app/assets/icons/polaris/GiftCardMinor.svg +1 -0
- data/app/assets/icons/polaris/GlobeMajor.svg +1 -0
- data/app/assets/icons/polaris/GlobeMinor.svg +1 -0
- data/app/assets/icons/polaris/GrammarMajor.svg +1 -0
- data/app/assets/icons/polaris/HashtagMajor.svg +1 -0
- data/app/assets/icons/polaris/HeaderMajor.svg +1 -0
- data/app/assets/icons/polaris/HeartMajor.svg +1 -0
- data/app/assets/icons/polaris/HideKeyboardMajor.svg +1 -0
- data/app/assets/icons/polaris/HideMinor.svg +1 -0
- data/app/assets/icons/polaris/HintMajor.svg +1 -0
- data/app/assets/icons/polaris/HomeMajor.svg +1 -0
- data/app/assets/icons/polaris/HorizontalDotsMinor.svg +1 -0
- data/app/assets/icons/polaris/IconsMajor.svg +1 -0
- data/app/assets/icons/polaris/IllustrationMajor.svg +1 -0
- data/app/assets/icons/polaris/ImageAltMajor.svg +1 -0
- data/app/assets/icons/polaris/ImageAltMinor.svg +1 -0
- data/app/assets/icons/polaris/ImageMajor.svg +1 -0
- data/app/assets/icons/polaris/ImageWithTextMajor.svg +1 -0
- data/app/assets/icons/polaris/ImageWithTextOverlayMajor.svg +1 -0
- data/app/assets/icons/polaris/ImagesMajor.svg +1 -0
- data/app/assets/icons/polaris/ImportMinor.svg +1 -0
- data/app/assets/icons/polaris/ImportStoreMajor.svg +1 -0
- data/app/assets/icons/polaris/IncomingMajor.svg +1 -0
- data/app/assets/icons/polaris/InfoMinor.svg +1 -0
- data/app/assets/icons/polaris/InstallMinor.svg +1 -0
- data/app/assets/icons/polaris/InventoryMajor.svg +1 -0
- data/app/assets/icons/polaris/InviteMinor.svg +1 -0
- data/app/assets/icons/polaris/IqMajor.svg +1 -0
- data/app/assets/icons/polaris/JobsMajor.svg +1 -0
- data/app/assets/icons/polaris/KeyMajor.svg +1 -0
- data/app/assets/icons/polaris/LabelPrinterMajor.svg +1 -0
- data/app/assets/icons/polaris/LandingPageMajor.svg +1 -0
- data/app/assets/icons/polaris/LanguageMinor.svg +1 -0
- data/app/assets/icons/polaris/LegalMajor.svg +1 -0
- data/app/assets/icons/polaris/LinkMinor.svg +1 -0
- data/app/assets/icons/polaris/ListMajor.svg +1 -0
- data/app/assets/icons/polaris/LiveViewMajor.svg +1 -0
- data/app/assets/icons/polaris/LocationMajor.svg +1 -0
- data/app/assets/icons/polaris/LocationsMinor.svg +1 -0
- data/app/assets/icons/polaris/LockMajor.svg +1 -0
- data/app/assets/icons/polaris/LockMinor.svg +1 -0
- data/app/assets/icons/polaris/LogOutMinor.svg +1 -0
- data/app/assets/icons/polaris/LogoBlockMajor.svg +1 -0
- data/app/assets/icons/polaris/ManagedStoreMajor.svg +1 -0
- data/app/assets/icons/polaris/MarkFulfilledMinor.svg +1 -0
- data/app/assets/icons/polaris/MarkPaidMinor.svg +1 -0
- data/app/assets/icons/polaris/MarketingMajor.svg +1 -0
- data/app/assets/icons/polaris/MaximizeMajor.svg +1 -0
- data/app/assets/icons/polaris/MaximizeMinor.svg +1 -0
- data/app/assets/icons/polaris/MentionMajor.svg +1 -0
- data/app/assets/icons/polaris/MicrophoneMajor.svg +1 -0
- data/app/assets/icons/polaris/MinimizeMajor.svg +1 -0
- data/app/assets/icons/polaris/MinimizeMinor.svg +1 -0
- data/app/assets/icons/polaris/MinusMinor.svg +1 -0
- data/app/assets/icons/polaris/MobileAcceptMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileBackArrowMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileCancelMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileChevronMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileHamburgerMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileHorizontalDotsMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileMajor.svg +1 -0
- data/app/assets/icons/polaris/MobilePlusMajor.svg +1 -0
- data/app/assets/icons/polaris/MobileVerticalDotsMajor.svg +1 -0
- data/app/assets/icons/polaris/MonerisMajor.svg +1 -0
- data/app/assets/icons/polaris/NatureMajor.svg +1 -0
- data/app/assets/icons/polaris/NavigationMajor.svg +1 -0
- data/app/assets/icons/polaris/NoteMajor.svg +1 -0
- data/app/assets/icons/polaris/NoteMinor.svg +1 -0
- data/app/assets/icons/polaris/NotificationMajor.svg +1 -0
- data/app/assets/icons/polaris/OnlineStoreMajor.svg +1 -0
- data/app/assets/icons/polaris/OrderStatusMinor.svg +1 -0
- data/app/assets/icons/polaris/OrdersMajor.svg +1 -0
- data/app/assets/icons/polaris/OutgoingMajor.svg +1 -0
- data/app/assets/icons/polaris/PackageMajor.svg +1 -0
- data/app/assets/icons/polaris/PageDownMajor.svg +1 -0
- data/app/assets/icons/polaris/PageMajor.svg +1 -0
- data/app/assets/icons/polaris/PageMinusMajor.svg +1 -0
- data/app/assets/icons/polaris/PagePlusMajor.svg +1 -0
- data/app/assets/icons/polaris/PageUpMajor.svg +1 -0
- data/app/assets/icons/polaris/PaginationEndMinor.svg +1 -0
- data/app/assets/icons/polaris/PaginationStartMinor.svg +1 -0
- data/app/assets/icons/polaris/PaintBrushMajor.svg +1 -0
- data/app/assets/icons/polaris/PauseCircleMajor.svg +1 -0
- data/app/assets/icons/polaris/PauseMajor.svg +1 -0
- data/app/assets/icons/polaris/PauseMinor.svg +1 -0
- data/app/assets/icons/polaris/PaymentsMajor.svg +1 -0
- data/app/assets/icons/polaris/PhoneInMajor.svg +1 -0
- data/app/assets/icons/polaris/PhoneMajor.svg +1 -0
- data/app/assets/icons/polaris/PhoneOutMajor.svg +1 -0
- data/app/assets/icons/polaris/PinMajor.svg +1 -0
- data/app/assets/icons/polaris/PinMinor.svg +1 -0
- data/app/assets/icons/polaris/PlayCircleMajor.svg +1 -0
- data/app/assets/icons/polaris/PlayMajor.svg +1 -0
- data/app/assets/icons/polaris/PlayMinor.svg +1 -0
- data/app/assets/icons/polaris/PlusMinor.svg +1 -0
- data/app/assets/icons/polaris/PointOfSaleMajor.svg +1 -0
- data/app/assets/icons/polaris/PopularMajor.svg +1 -0
- data/app/assets/icons/polaris/PriceLookupMinor.svg +1 -0
- data/app/assets/icons/polaris/PrintMajor.svg +1 -0
- data/app/assets/icons/polaris/PrintMinor.svg +1 -0
- data/app/assets/icons/polaris/ProductReturnsMinor.svg +1 -0
- data/app/assets/icons/polaris/ProductsMajor.svg +1 -0
- data/app/assets/icons/polaris/ProfileMajor.svg +1 -0
- data/app/assets/icons/polaris/ProfileMinor.svg +1 -0
- data/app/assets/icons/polaris/PromoteMinor.svg +1 -0
- data/app/assets/icons/polaris/QuestionMarkMajor.svg +1 -0
- data/app/assets/icons/polaris/QuestionMarkMinor.svg +1 -0
- data/app/assets/icons/polaris/QuickSaleMajor.svg +1 -0
- data/app/assets/icons/polaris/ReadTimeMinor.svg +1 -0
- data/app/assets/icons/polaris/ReceiptMajor.svg +1 -0
- data/app/assets/icons/polaris/RecentSearchesMajor.svg +1 -0
- data/app/assets/icons/polaris/RedoMajor.svg +1 -0
- data/app/assets/icons/polaris/ReferralCodeMajor.svg +1 -0
- data/app/assets/icons/polaris/ReferralMajor.svg +1 -0
- data/app/assets/icons/polaris/RefreshMajor.svg +1 -0
- data/app/assets/icons/polaris/RefreshMinor.svg +1 -0
- data/app/assets/icons/polaris/RefundMajor.svg +1 -0
- data/app/assets/icons/polaris/RefundMinor.svg +1 -0
- data/app/assets/icons/polaris/RemoveProductMajor.svg +1 -0
- data/app/assets/icons/polaris/RepeatOrderMajor.svg +1 -0
- data/app/assets/icons/polaris/ReplaceMajor.svg +1 -0
- data/app/assets/icons/polaris/ReplayMinor.svg +1 -0
- data/app/assets/icons/polaris/ReportMinor.svg +1 -0
- data/app/assets/icons/polaris/ReportsMajor.svg +1 -0
- data/app/assets/icons/polaris/ResetMinor.svg +1 -0
- data/app/assets/icons/polaris/ResourcesMajor.svg +1 -0
- data/app/assets/icons/polaris/ReturnMinor.svg +1 -0
- data/app/assets/icons/polaris/RiskMajor.svg +1 -0
- data/app/assets/icons/polaris/RiskMinor.svg +1 -0
- data/app/assets/icons/polaris/SandboxMajor.svg +1 -0
- data/app/assets/icons/polaris/SaveMinor.svg +1 -0
- data/app/assets/icons/polaris/SearchMajor.svg +1 -0
- data/app/assets/icons/polaris/SearchMinor.svg +1 -0
- data/app/assets/icons/polaris/SectionMajor.svg +1 -0
- data/app/assets/icons/polaris/SecureMajor.svg +1 -0
- data/app/assets/icons/polaris/SelectMinor.svg +1 -0
- data/app/assets/icons/polaris/SendMajor.svg +1 -0
- data/app/assets/icons/polaris/SettingsMajor.svg +1 -0
- data/app/assets/icons/polaris/SettingsMinor.svg +1 -0
- data/app/assets/icons/polaris/ShareIosMinor.svg +1 -0
- data/app/assets/icons/polaris/ShareMinor.svg +1 -0
- data/app/assets/icons/polaris/ShipmentMajor.svg +1 -0
- data/app/assets/icons/polaris/ShopcodesMajor.svg +1 -0
- data/app/assets/icons/polaris/SidebarLeftMajor.svg +1 -0
- data/app/assets/icons/polaris/SidebarRightMajor.svg +1 -0
- data/app/assets/icons/polaris/SlideshowMajor.svg +1 -0
- data/app/assets/icons/polaris/SmileyHappyMajor.svg +1 -0
- data/app/assets/icons/polaris/SmileyJoyMajor.svg +1 -0
- data/app/assets/icons/polaris/SmileyNeutralMajor.svg +1 -0
- data/app/assets/icons/polaris/SmileySadMajor.svg +1 -0
- data/app/assets/icons/polaris/SocialAdMajor.svg +1 -0
- data/app/assets/icons/polaris/SocialPostMajor.svg +1 -0
- data/app/assets/icons/polaris/SoftPackMajor.svg +1 -0
- data/app/assets/icons/polaris/SortAscendingMajor.svg +1 -0
- data/app/assets/icons/polaris/SortDescendingMajor.svg +1 -0
- data/app/assets/icons/polaris/SortMinor.svg +1 -0
- data/app/assets/icons/polaris/SoundMajor.svg +1 -0
- data/app/assets/icons/polaris/StarFilledMinor.svg +1 -0
- data/app/assets/icons/polaris/StarOutlineMinor.svg +1 -0
- data/app/assets/icons/polaris/StoreMajor.svg +1 -0
- data/app/assets/icons/polaris/StoreMinor.svg +1 -0
- data/app/assets/icons/polaris/StoreStatusMajor.svg +1 -0
- data/app/assets/icons/polaris/TabletMajor.svg +1 -0
- data/app/assets/icons/polaris/TapChipMajor.svg +1 -0
- data/app/assets/icons/polaris/TaxMajor.svg +1 -0
- data/app/assets/icons/polaris/TeamMajor.svg +1 -0
- data/app/assets/icons/polaris/TemplateMajor.svg +1 -0
- data/app/assets/icons/polaris/TextAlignmentCenterMajor.svg +1 -0
- data/app/assets/icons/polaris/TextAlignmentLeftMajor.svg +1 -0
- data/app/assets/icons/polaris/TextAlignmentRightMajor.svg +1 -0
- data/app/assets/icons/polaris/TextBlockMajor.svg +1 -0
- data/app/assets/icons/polaris/TextMajor.svg +1 -0
- data/app/assets/icons/polaris/ThemeEditMajor.svg +1 -0
- data/app/assets/icons/polaris/ThemeStoreMajor.svg +1 -0
- data/app/assets/icons/polaris/ThemesMajor.svg +1 -0
- data/app/assets/icons/polaris/ThumbsDownMajor.svg +1 -0
- data/app/assets/icons/polaris/ThumbsDownMinor.svg +1 -0
- data/app/assets/icons/polaris/ThumbsUpMajor.svg +1 -0
- data/app/assets/icons/polaris/ThumbsUpMinor.svg +1 -0
- data/app/assets/icons/polaris/TickMinor.svg +1 -0
- data/app/assets/icons/polaris/TickSmallMinor.svg +1 -0
- data/app/assets/icons/polaris/TimelineAttachmentMajor.svg +1 -0
- data/app/assets/icons/polaris/TipsMajor.svg +1 -0
- data/app/assets/icons/polaris/ToolsMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionFeeDollarMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionFeeEuroMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionFeePoundMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionFeeRupeeMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionFeeYenMajor.svg +1 -0
- data/app/assets/icons/polaris/TransactionMajor.svg +1 -0
- data/app/assets/icons/polaris/TransferInMajor.svg +1 -0
- data/app/assets/icons/polaris/TransferMajor.svg +1 -0
- data/app/assets/icons/polaris/TransferOutMajor.svg +1 -0
- data/app/assets/icons/polaris/TransferWithinShopifyMajor.svg +1 -0
- data/app/assets/icons/polaris/TransportMajor.svg +1 -0
- data/app/assets/icons/polaris/TroubleshootMajor.svg +1 -0
- data/app/assets/icons/polaris/TypeMajor.svg +1 -0
- data/app/assets/icons/polaris/UndoMajor.svg +1 -0
- data/app/assets/icons/polaris/UnfulfilledMajor.svg +1 -0
- data/app/assets/icons/polaris/UnknownDeviceMajor.svg +1 -0
- data/app/assets/icons/polaris/UpdateInventoryMajor.svg +1 -0
- data/app/assets/icons/polaris/UploadMajor.svg +1 -0
- data/app/assets/icons/polaris/VariantMajor.svg +1 -0
- data/app/assets/icons/polaris/ViewMajor.svg +1 -0
- data/app/assets/icons/polaris/ViewMinor.svg +1 -0
- data/app/assets/icons/polaris/ViewportNarrowMajor.svg +1 -0
- data/app/assets/icons/polaris/ViewportWideMajor.svg +1 -0
- data/app/assets/icons/polaris/VocabularyMajor.svg +1 -0
- data/app/assets/icons/polaris/WandMajor.svg +1 -0
- data/app/assets/icons/polaris/WearableMajor.svg +1 -0
- data/app/assets/icons/polaris/WholesaleMajor.svg +1 -0
- data/app/assets/icons/polaris/WifiMajor.svg +1 -0
- data/app/assets/javascripts/polaris.js +113 -0
- data/app/assets/stylesheets/polaris_view_components.css +136 -0
- data/app/components/polaris/action.rb +32 -0
- data/app/components/polaris/application_component.rb +35 -0
- data/app/components/polaris/avatar_component.html.erb +19 -0
- data/app/components/polaris/avatar_component.rb +39 -0
- data/app/components/polaris/badge_component.html.erb +9 -0
- data/app/components/polaris/badge_component.rb +51 -0
- data/app/components/polaris/banner_component.html.erb +42 -0
- data/app/components/polaris/banner_component.rb +89 -0
- data/app/components/polaris/base_button.rb +31 -0
- data/app/components/polaris/base_component.rb +23 -0
- data/app/components/polaris/button_component.html.erb +24 -0
- data/app/components/polaris/button_component.rb +90 -0
- data/app/components/polaris/button_group_component.html.erb +5 -0
- data/app/components/polaris/button_group_component.rb +109 -0
- data/app/components/polaris/callout_card_component.html.erb +46 -0
- data/app/components/polaris/callout_card_component.rb +45 -0
- data/app/components/polaris/caption_component.rb +18 -0
- data/app/components/polaris/card/header_component.html.erb +25 -0
- data/app/components/polaris/card/header_component.rb +23 -0
- data/app/components/polaris/card/section_component.html.erb +31 -0
- data/app/components/polaris/card/section_component.rb +40 -0
- data/app/components/polaris/card_component.html.erb +51 -0
- data/app/components/polaris/card_component.rb +52 -0
- data/app/components/polaris/character_count.rb +50 -0
- data/app/components/polaris/checkbox_component.html.erb +15 -0
- data/app/components/polaris/checkbox_component.rb +78 -0
- data/app/components/polaris/choice_component.html.erb +35 -0
- data/app/components/polaris/choice_component.rb +29 -0
- data/app/components/polaris/choice_list/component.html.erb +34 -0
- data/app/components/polaris/choice_list/component.rb +65 -0
- data/app/components/polaris/choice_list_component.html.erb +19 -0
- data/app/components/polaris/choice_list_component.rb +68 -0
- data/app/components/polaris/component.rb +5 -0
- data/app/components/polaris/description_list_component.html.erb +5 -0
- data/app/components/polaris/description_list_component.rb +41 -0
- data/app/components/polaris/display_text_component.rb +35 -0
- data/app/components/polaris/dropzone/component.html.erb +72 -0
- data/app/components/polaris/dropzone/component.rb +130 -0
- data/app/components/polaris/dropzone/controller.js +226 -0
- data/app/components/polaris/dropzone/utils.js +57 -0
- data/app/components/polaris/empty_state_component.html.erb +47 -0
- data/app/components/polaris/empty_state_component.rb +38 -0
- data/app/components/polaris/exception_list/item_component.html.erb +19 -0
- data/app/components/polaris/exception_list/item_component.rb +27 -0
- data/app/components/polaris/exception_list_component.html.erb +5 -0
- data/app/components/polaris/exception_list_component.rb +20 -0
- data/app/components/polaris/footer_help_component.html.erb +11 -0
- data/app/components/polaris/footer_help_component.rb +13 -0
- data/app/components/polaris/form_layout/group_component.html.erb +7 -0
- data/app/components/polaris/form_layout/group_component.rb +39 -0
- data/app/components/polaris/form_layout/item_component.rb +18 -0
- data/app/components/polaris/form_layout_component.html.erb +5 -0
- data/app/components/polaris/form_layout_component.rb +37 -0
- data/app/components/polaris/heading_component.rb +24 -0
- data/app/components/polaris/icon_component.html.erb +7 -0
- data/app/components/polaris/icon_component.rb +36 -0
- data/app/components/polaris/inline_error_component.html.erb +6 -0
- data/app/components/polaris/inline_error_component.rb +12 -0
- data/app/components/polaris/label_component.html.erb +21 -0
- data/app/components/polaris/label_component.rb +36 -0
- data/app/components/polaris/labelled_component.html.erb +25 -0
- data/app/components/polaris/labelled_component.rb +49 -0
- data/app/components/polaris/layout/annotated_section.html.erb +19 -0
- data/app/components/polaris/layout/annotated_section.rb +21 -0
- data/app/components/polaris/layout/section.rb +35 -0
- data/app/components/polaris/layout_component.html.erb +5 -0
- data/app/components/polaris/layout_component.rb +48 -0
- data/app/components/polaris/link_component.rb +48 -0
- data/app/components/polaris/list_component.html.erb +5 -0
- data/app/components/polaris/list_component.rb +46 -0
- data/app/components/polaris/new_component.rb +10 -0
- data/app/components/polaris/page_actions_component.html.erb +21 -0
- data/app/components/polaris/page_actions_component.rb +24 -0
- data/app/components/polaris/page_component.html.erb +63 -0
- data/app/components/polaris/page_component.rb +56 -0
- data/app/components/polaris/pagination_component.html.erb +19 -0
- data/app/components/polaris/pagination_component.rb +26 -0
- data/app/components/polaris/progress_bar_component.html.erb +14 -0
- data/app/components/polaris/progress_bar_component.rb +41 -0
- data/app/components/polaris/radio_button_component.html.erb +11 -0
- data/app/components/polaris/radio_button_component.rb +55 -0
- data/app/components/polaris/select_component.html.erb +36 -0
- data/app/components/polaris/select_component.rb +75 -0
- data/app/components/polaris/shopify_navigation_component.html.erb +9 -0
- data/app/components/polaris/shopify_navigation_component.rb +43 -0
- data/app/components/polaris/spinner_component.html.erb +11 -0
- data/app/components/polaris/spinner_component.rb +25 -0
- data/app/components/polaris/stack_component.html.erb +7 -0
- data/app/components/polaris/stack_component.rb +79 -0
- data/app/components/polaris/subheading_component.rb +24 -0
- data/app/components/polaris/text_container_component.rb +30 -0
- data/app/components/polaris/text_field_component.html.erb +103 -0
- data/app/components/polaris/text_field_component.rb +181 -0
- data/app/components/polaris/text_style_component.rb +32 -0
- data/app/components/polaris/thumbnail_component.html.erb +7 -0
- data/app/components/polaris/thumbnail_component.rb +37 -0
- data/app/components/polaris/visually_hidden_component.rb +12 -0
- data/app/helpers/polaris/action_helper.rb +14 -0
- data/app/helpers/polaris/class_name_helper.rb +24 -0
- data/app/helpers/polaris/conditional_helper.rb +11 -0
- data/app/helpers/polaris/fetch_or_fallback_helper.rb +53 -0
- data/app/helpers/polaris/form_builder.rb +16 -0
- data/app/helpers/polaris/option_helper.rb +13 -0
- data/app/helpers/polaris/view_helper.rb +66 -0
- data/app/javascript/polaris/index.js +9 -0
- data/app/javascript/polaris/select_controller.js +12 -0
- data/app/javascript/polaris/text_field_controller.js +112 -0
- data/app/validators/type_validator.rb +15 -0
- data/lib/polaris/view_components.rb +7 -0
- data/lib/polaris/view_components/engine.rb +29 -0
- data/lib/polaris/view_components/version.rb +5 -0
- data/lib/polaris_view_components.rb +1 -0
- metadata +588 -0
@@ -0,0 +1,51 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class BadgeComponent < Polaris::NewComponent
|
5
|
+
PROGRESS_DEFAULT = :default
|
6
|
+
PROGRESS_MAPPINGS = {
|
7
|
+
PROGRESS_DEFAULT => "",
|
8
|
+
:incomplete => "Polaris-Badge--progressIncomplete",
|
9
|
+
:partially_complete => "Polaris-Badge--progressPartiallyComplete",
|
10
|
+
:complete => "Polaris-Badge--progressComplete"
|
11
|
+
}
|
12
|
+
PROGRESS_OPTIONS = PROGRESS_MAPPINGS.keys
|
13
|
+
|
14
|
+
SIZE_DEFAULT = :medium
|
15
|
+
SIZE_MAPPINGS = {
|
16
|
+
SIZE_DEFAULT => "",
|
17
|
+
:small => "Polaris-Badge--sizeSmall"
|
18
|
+
}
|
19
|
+
SIZE_OPTIONS = SIZE_MAPPINGS.keys
|
20
|
+
|
21
|
+
STATUS_DEFAULT = :default
|
22
|
+
STATUS_MAPPINGS = {
|
23
|
+
STATUS_DEFAULT => "",
|
24
|
+
:success => "Polaris-Badge--statusSuccess",
|
25
|
+
:info => "Polaris-Badge--statusInfo",
|
26
|
+
:attention => "Polaris-Badge--statusAttention",
|
27
|
+
:critical => "Polaris-Badge--statusCritical",
|
28
|
+
:warning => "Polaris-Badge--statusWarning",
|
29
|
+
:new => "Polaris-Badge--statusNew"
|
30
|
+
}
|
31
|
+
STATUS_OPTIONS = STATUS_MAPPINGS.keys
|
32
|
+
|
33
|
+
def initialize(
|
34
|
+
progress: PROGRESS_DEFAULT,
|
35
|
+
size: SIZE_DEFAULT,
|
36
|
+
status: STATUS_DEFAULT,
|
37
|
+
**system_arguments
|
38
|
+
)
|
39
|
+
@progress = progress
|
40
|
+
|
41
|
+
@system_arguments = system_arguments
|
42
|
+
@system_arguments[:classes] = class_names(
|
43
|
+
@system_arguments[:classes],
|
44
|
+
"Polaris-Badge",
|
45
|
+
PROGRESS_MAPPINGS[fetch_or_fallback(PROGRESS_OPTIONS, progress, PROGRESS_DEFAULT)],
|
46
|
+
SIZE_MAPPINGS[fetch_or_fallback(SIZE_OPTIONS, size, SIZE_DEFAULT)],
|
47
|
+
STATUS_MAPPINGS[fetch_or_fallback(STATUS_OPTIONS, status, STATUS_DEFAULT)],
|
48
|
+
)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
<%= render Polaris::BaseComponent.new(tag: 'div', **@system_arguments) do %>
|
2
|
+
<% if dismiss_button %>
|
3
|
+
<div class="Polaris-Banner__Dismiss">
|
4
|
+
<%= dismiss_button %>
|
5
|
+
</div>
|
6
|
+
<% end %>
|
7
|
+
<div class="Polaris-Banner__Ribbon">
|
8
|
+
<%= render_icon %>
|
9
|
+
</div>
|
10
|
+
<div class="Polaris-Banner__ContentWrapper">
|
11
|
+
<% if @title.present? %>
|
12
|
+
<div class="Polaris-Banner__Heading">
|
13
|
+
<p class="Polaris-Heading">
|
14
|
+
<%= @title %>
|
15
|
+
</p>
|
16
|
+
</div>
|
17
|
+
<% end %>
|
18
|
+
<div class="Polaris-Banner__Content">
|
19
|
+
<%= content %>
|
20
|
+
|
21
|
+
<% if action || secondary_action %>
|
22
|
+
<div class="Polaris-Banner__Actions">
|
23
|
+
<%= polaris_button_group do |group| %>
|
24
|
+
<% if action %>
|
25
|
+
<% group.item do %>
|
26
|
+
<div class="Polaris-Banner__PrimaryAction">
|
27
|
+
<%= action %>
|
28
|
+
</div>
|
29
|
+
<% end %>
|
30
|
+
<% end %>
|
31
|
+
|
32
|
+
<% if secondary_action %>
|
33
|
+
<% group.item do %>
|
34
|
+
<%= secondary_action %>
|
35
|
+
<% end %>
|
36
|
+
<% end %>
|
37
|
+
<% end %>
|
38
|
+
</div>
|
39
|
+
<% end %>
|
40
|
+
</div>
|
41
|
+
</div>
|
42
|
+
<% end %>
|
@@ -0,0 +1,89 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class BannerComponent < Polaris::NewComponent
|
5
|
+
STATUS_DEFAULT = :default
|
6
|
+
STATUS_MAPPINGS = {
|
7
|
+
STATUS_DEFAULT => "",
|
8
|
+
:success => "Polaris-Banner--statusSuccess",
|
9
|
+
:info => "Polaris-Banner--statusInfo",
|
10
|
+
:warning => "Polaris-Banner--statusWarning",
|
11
|
+
:critical => "Polaris-Banner--statusCritical",
|
12
|
+
}
|
13
|
+
STATUS_OPTIONS = STATUS_MAPPINGS.keys
|
14
|
+
|
15
|
+
WITHIN_DEFAULT = :page
|
16
|
+
WITHIN_MAPPINGS = {
|
17
|
+
page: "Polaris-Banner--withinPage",
|
18
|
+
container: "Polaris-Banner--withinContentContainer",
|
19
|
+
}
|
20
|
+
WITHIN_OPTIONS = WITHIN_MAPPINGS.keys
|
21
|
+
|
22
|
+
ICON_COLOR_MAPPINGS = {
|
23
|
+
default: :base,
|
24
|
+
success: :success,
|
25
|
+
info: :highlight,
|
26
|
+
warning: :warning,
|
27
|
+
critical: :critical,
|
28
|
+
}
|
29
|
+
|
30
|
+
renders_one :action, -> (**system_arguments) do
|
31
|
+
Polaris::ButtonComponent.new(classes: "Polaris-Banner__Button", **system_arguments)
|
32
|
+
end
|
33
|
+
renders_one :secondary_action, "SecondaryAction"
|
34
|
+
renders_one :dismiss_button, -> (**system_arguments) do
|
35
|
+
render Polaris::ButtonComponent.new(plain: true, **system_arguments) do |button|
|
36
|
+
button.icon(name: "CancelSmallMinor")
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def initialize(
|
41
|
+
status: STATUS_DEFAULT,
|
42
|
+
within: WITHIN_DEFAULT,
|
43
|
+
icon: nil,
|
44
|
+
title: nil,
|
45
|
+
**system_arguments
|
46
|
+
)
|
47
|
+
@status = status
|
48
|
+
@icon = icon || default_icon(status)
|
49
|
+
@title = title
|
50
|
+
|
51
|
+
@system_arguments = system_arguments
|
52
|
+
@system_arguments[:tabindex] = 0
|
53
|
+
@system_arguments[:role] = "status"
|
54
|
+
@system_arguments[:classes] = class_names(
|
55
|
+
@system_arguments[:classes],
|
56
|
+
"Polaris-Banner",
|
57
|
+
STATUS_MAPPINGS[fetch_or_fallback(STATUS_OPTIONS, status, STATUS_DEFAULT)],
|
58
|
+
WITHIN_MAPPINGS[fetch_or_fallback(WITHIN_OPTIONS, within, WITHIN_DEFAULT)],
|
59
|
+
)
|
60
|
+
end
|
61
|
+
|
62
|
+
def render_icon
|
63
|
+
polaris_icon(name: @icon, color: ICON_COLOR_MAPPINGS[@status])
|
64
|
+
end
|
65
|
+
|
66
|
+
def default_icon(status)
|
67
|
+
case status
|
68
|
+
when :success then "CircleTickMajor"
|
69
|
+
when :critical then "DiamondAlertMajor"
|
70
|
+
else
|
71
|
+
"CircleInformationMajor"
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
class SecondaryAction < Polaris::NewComponent
|
76
|
+
def initialize(**system_arguments)
|
77
|
+
@system_arguments = system_arguments
|
78
|
+
end
|
79
|
+
|
80
|
+
def call
|
81
|
+
render(BaseButton.new(classes: "Polaris-Banner__SecondaryAction", **@system_arguments)) do
|
82
|
+
tag.span(class: "Polaris-Banner__Text") do
|
83
|
+
content
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class BaseButton < Polaris::NewComponent
|
5
|
+
def initialize(
|
6
|
+
url: nil,
|
7
|
+
external: false,
|
8
|
+
disabled: false,
|
9
|
+
loading: false,
|
10
|
+
**system_arguments
|
11
|
+
)
|
12
|
+
@system_arguments = system_arguments
|
13
|
+
@system_arguments[:tag] = url.present? ? 'a' : 'button'
|
14
|
+
if loading
|
15
|
+
@system_arguments[:disabled] = true
|
16
|
+
end
|
17
|
+
if url.present?
|
18
|
+
@system_arguments.delete(:type)
|
19
|
+
@system_arguments[:href] = url
|
20
|
+
@system_arguments[:target] = "_blank" if external
|
21
|
+
end
|
22
|
+
if disabled
|
23
|
+
@system_arguments[:disabled] = disabled
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def call
|
28
|
+
render(Polaris::BaseComponent.new(**@system_arguments)) { content }
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class BaseComponent < Polaris::NewComponent
|
5
|
+
def initialize(tag:, classes: nil, **system_arguments)
|
6
|
+
@tag = tag
|
7
|
+
@system_arguments = system_arguments
|
8
|
+
@content_tag_args = prepare_arguments(@system_arguments.merge(classes: classes))
|
9
|
+
end
|
10
|
+
|
11
|
+
def call
|
12
|
+
content_tag(@tag, content, @content_tag_args)
|
13
|
+
end
|
14
|
+
|
15
|
+
private
|
16
|
+
|
17
|
+
def prepare_arguments(arguments)
|
18
|
+
arguments[:class] = arguments[:classes]
|
19
|
+
arguments.delete(:classes)
|
20
|
+
arguments
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<%= render Polaris::BaseComponent.new(tag: @tag, **dynamic_arguments) do %>
|
2
|
+
<span class="Polaris-Button__Content">
|
3
|
+
<% if @loading %>
|
4
|
+
<span class="Polaris-Button__Spinner">
|
5
|
+
<%= polaris_spinner(size: :small) %>
|
6
|
+
</span>
|
7
|
+
<% end %>
|
8
|
+
|
9
|
+
<% if icon.present? %>
|
10
|
+
<div class="Polaris-Button__Icon">
|
11
|
+
<%= icon %>
|
12
|
+
</div>
|
13
|
+
<% if content.present? %>
|
14
|
+
|
15
|
+
<% end %>
|
16
|
+
<% end %>
|
17
|
+
|
18
|
+
<% if content.present? %>
|
19
|
+
<div class="<%= @text_classes %>">
|
20
|
+
<%= content %>
|
21
|
+
</div>
|
22
|
+
<% end %>
|
23
|
+
</span>
|
24
|
+
<% end %>
|
@@ -0,0 +1,90 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class ButtonComponent < Polaris::NewComponent
|
5
|
+
SIZE_DEFAULT = :medium
|
6
|
+
SIZE_MAPPINGS = {
|
7
|
+
SIZE_DEFAULT => "",
|
8
|
+
:slim => "Polaris-Button--sizeSlim",
|
9
|
+
:large => "Polaris-Button--sizeLarge",
|
10
|
+
}
|
11
|
+
SIZE_OPTIONS = SIZE_MAPPINGS.keys
|
12
|
+
|
13
|
+
TEXT_ALIGN_DEFAULT = :default
|
14
|
+
TEXT_ALIGN_MAPPINGS = {
|
15
|
+
TEXT_ALIGN_DEFAULT => "",
|
16
|
+
:left => "Polaris-Button--textAlignLeft",
|
17
|
+
:center => "Polaris-Button--textAlignCenter",
|
18
|
+
:right => "Polaris-Button--textAlignRight",
|
19
|
+
}
|
20
|
+
TEXT_ALIGN_OPTIONS = TEXT_ALIGN_MAPPINGS.keys
|
21
|
+
|
22
|
+
renders_one :icon, IconComponent
|
23
|
+
|
24
|
+
def initialize(
|
25
|
+
url: nil,
|
26
|
+
outline: false,
|
27
|
+
plain: false,
|
28
|
+
primary: false,
|
29
|
+
pressed: false,
|
30
|
+
monochrome: false,
|
31
|
+
loading: false,
|
32
|
+
destructive: false,
|
33
|
+
disabled: false,
|
34
|
+
external: false,
|
35
|
+
full_width: false,
|
36
|
+
submit: false,
|
37
|
+
remove_underline: false,
|
38
|
+
size: SIZE_DEFAULT,
|
39
|
+
text_align: TEXT_ALIGN_DEFAULT,
|
40
|
+
**system_arguments
|
41
|
+
)
|
42
|
+
@tag = url.present? ? 'a' : 'button'
|
43
|
+
@text_classes = class_names(
|
44
|
+
"Polaris-Button__Text",
|
45
|
+
"Polaris-Button--removeUnderline": plain && monochrome && remove_underline
|
46
|
+
)
|
47
|
+
@loading = loading
|
48
|
+
|
49
|
+
@system_arguments = system_arguments
|
50
|
+
@system_arguments[:type] = submit ? 'submit' : 'button'
|
51
|
+
if loading
|
52
|
+
@system_arguments[:disabled] = true
|
53
|
+
end
|
54
|
+
if url.present?
|
55
|
+
@system_arguments.delete(:type)
|
56
|
+
@system_arguments[:href] = url
|
57
|
+
@system_arguments[:target] = "_blank" if external
|
58
|
+
end
|
59
|
+
if disabled
|
60
|
+
@system_arguments[:disabled] = disabled
|
61
|
+
end
|
62
|
+
@system_arguments[:classes] = class_names(
|
63
|
+
@system_arguments[:classes],
|
64
|
+
"Polaris-Button",
|
65
|
+
SIZE_MAPPINGS[fetch_or_fallback(SIZE_OPTIONS, size, SIZE_DEFAULT)],
|
66
|
+
TEXT_ALIGN_MAPPINGS[fetch_or_fallback(TEXT_ALIGN_OPTIONS, text_align, TEXT_ALIGN_DEFAULT)],
|
67
|
+
"Polaris-Button--destructive": destructive,
|
68
|
+
"Polaris-Button--disabled": disabled || loading,
|
69
|
+
"Polaris-Button--loading": loading,
|
70
|
+
"Polaris-Button--fullWidth": full_width,
|
71
|
+
"Polaris-Button--monochrome": monochrome,
|
72
|
+
"Polaris-Button--outline": outline,
|
73
|
+
"Polaris-Button--plain": plain,
|
74
|
+
"Polaris-Button--primary": primary,
|
75
|
+
"Polaris-Button--pressed": pressed,
|
76
|
+
"Polaris-Button--removeUnderline": (plain && monochrome && remove_underline)
|
77
|
+
)
|
78
|
+
end
|
79
|
+
|
80
|
+
private
|
81
|
+
|
82
|
+
def dynamic_arguments
|
83
|
+
@system_arguments[:classes] = class_names(
|
84
|
+
@system_arguments[:classes],
|
85
|
+
"Polaris-Button--iconOnly": icon.present? && content.blank?,
|
86
|
+
)
|
87
|
+
@system_arguments
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
@@ -0,0 +1,109 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Polaris
|
4
|
+
class ButtonGroupComponent < Polaris::NewComponent
|
5
|
+
SPACING_DEFAULT = :default
|
6
|
+
SPACING_MAPPINGS = {
|
7
|
+
SPACING_DEFAULT => "",
|
8
|
+
:extra_tight => "Polaris-ButtonGroup--extraTight",
|
9
|
+
:tight => "Polaris-ButtonGroup--tight",
|
10
|
+
:loose => "Polaris-ButtonGroup--loose",
|
11
|
+
}
|
12
|
+
SPACING_OPTIONS = SPACING_MAPPINGS.keys
|
13
|
+
|
14
|
+
renders_many :buttons, -> (**system_arguments) do
|
15
|
+
@counter += 1
|
16
|
+
|
17
|
+
ButtonGroupItemButtonComponent.new(position: @counter, **system_arguments)
|
18
|
+
end
|
19
|
+
|
20
|
+
renders_many :items, -> (**system_arguments) do
|
21
|
+
@counter += 1
|
22
|
+
|
23
|
+
ButtonGroupItemComponent.new(position: @counter, **system_arguments)
|
24
|
+
end
|
25
|
+
|
26
|
+
def initialize(
|
27
|
+
connected_top: false,
|
28
|
+
full_width: false,
|
29
|
+
segmented: false,
|
30
|
+
spacing: SPACING_DEFAULT,
|
31
|
+
**system_arguments
|
32
|
+
)
|
33
|
+
@counter = 0
|
34
|
+
|
35
|
+
@system_arguments = system_arguments
|
36
|
+
if connected_top
|
37
|
+
@system_arguments["data-buttongroup-connected-top"] = true
|
38
|
+
end
|
39
|
+
if full_width
|
40
|
+
@system_arguments["data-buttongroup-full-width"] = true
|
41
|
+
end
|
42
|
+
if segmented
|
43
|
+
@system_arguments["data-buttongroup-segmented"] = true
|
44
|
+
end
|
45
|
+
@system_arguments[:classes] = class_names(
|
46
|
+
@system_arguments[:classes],
|
47
|
+
"Polaris-ButtonGroup",
|
48
|
+
SPACING_MAPPINGS[fetch_or_fallback(SPACING_OPTIONS, spacing, SPACING_DEFAULT)],
|
49
|
+
"Polaris-ButtonGroup--fullWidth": full_width,
|
50
|
+
"Polaris-ButtonGroup--segmented": segmented,
|
51
|
+
)
|
52
|
+
end
|
53
|
+
|
54
|
+
def render?
|
55
|
+
all_items.any?
|
56
|
+
end
|
57
|
+
|
58
|
+
def all_items
|
59
|
+
@all_items ||= buttons + items
|
60
|
+
end
|
61
|
+
|
62
|
+
def ordered_items
|
63
|
+
all_items.sort_by(&:position)
|
64
|
+
end
|
65
|
+
|
66
|
+
class ButtonGroupItemButtonComponent < Polaris::NewComponent
|
67
|
+
attr_reader :position
|
68
|
+
|
69
|
+
def initialize(position:, **system_arguments)
|
70
|
+
@position = position
|
71
|
+
|
72
|
+
@system_arguments = system_arguments
|
73
|
+
@system_arguments[:tag] = :div
|
74
|
+
@system_arguments[:classes] = class_names(
|
75
|
+
@system_arguments[:classes],
|
76
|
+
"Polaris-ButtonGroup__Item",
|
77
|
+
"Polaris-ButtonGroup__Item--plain": system_arguments.key?(:plain)
|
78
|
+
)
|
79
|
+
end
|
80
|
+
|
81
|
+
def call
|
82
|
+
button_arguments = @system_arguments.except(:classes, :tag)
|
83
|
+
|
84
|
+
render(Polaris::BaseComponent.new(tag: @system_arguments[:tag], classes: @system_arguments[:classes])) do
|
85
|
+
render(Polaris::ButtonComponent.new(**button_arguments)) { button_arguments[:content] || content }
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
class ButtonGroupItemComponent < Polaris::NewComponent
|
91
|
+
attr_reader :position
|
92
|
+
|
93
|
+
def initialize(position:, **system_arguments)
|
94
|
+
@position = position
|
95
|
+
|
96
|
+
@system_arguments = system_arguments
|
97
|
+
@system_arguments[:tag] = :div
|
98
|
+
@system_arguments[:classes] = class_names(
|
99
|
+
@system_arguments[:classes],
|
100
|
+
"Polaris-ButtonGroup__Item",
|
101
|
+
)
|
102
|
+
end
|
103
|
+
|
104
|
+
def call
|
105
|
+
render(Polaris::BaseComponent.new(**@system_arguments)) { content }
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|