UNPKG

@ionic/core

Version:
227 lines (202 loc) • 6.59 kB
:host { --transition: background-color, opacity 100ms linear; --ripple-color: currentColor; --border-radius: 50%; --border-width: 0; --border-style: none; --border-color: initial; --padding-top: 0; --padding-end: 0; --padding-bottom: 0; --padding-start: 0; /** * @prop --background: Background of the button * @prop --background-activated: Background of the button when activated * @prop --background-focused: Background of the button when focused * * @prop --color: Text color of the button * @prop --color-activated: Text color of the button when activated * @prop --color-focused: Text color of the button when focused * * @prop --transition: Transition of the button * * @prop --border-radius: Border radius of the button * @prop --border-width: Border width of the button * @prop --border-style: Border style of the button * @prop --border-color: Border color of the button * * @prop --ripple-color: Color of the button ripple effect * * @prop --box-shadow: Box shadow of the button * * @prop --padding-top: Padding top of the button * @prop --padding-end: Padding end of the button * @prop --padding-bottom: Padding bottom of the button * @prop --padding-start: Padding start of the button */ margin-left: 0; margin-right: 0; margin-top: 0; margin-bottom: 0; display: block; width: 56px; height: 56px; font-size: 14px; text-align: center; text-overflow: ellipsis; text-transform: none; white-space: nowrap; font-kerning: none; } :host(.ion-color) .button-native { background: var(--ion-color-base); color: var(--ion-color-contrast); } :host(.ion-color.ion-focused) .button-native, :host(.ion-color.activated) .button-native { background: var(--ion-color-shade); color: var(--ion-color-contrast); } .button-native { border-radius: var(--border-radius); padding-left: var(--padding-start); padding-right: var(--padding-end); padding-top: var(--padding-top); padding-bottom: var(--padding-bottom); font-family: inherit; font-size: inherit; font-style: inherit; font-weight: inherit; letter-spacing: inherit; text-decoration: inherit; text-overflow: inherit; text-transform: inherit; text-align: inherit; white-space: inherit; color: inherit; display: block; position: relative; width: 100%; height: 100%; transform: var(--transform); transition: var(--transition); border-width: var(--border-width); border-style: var(--border-style); border-color: var(--border-color); outline: none; background: var(--background); background-clip: padding-box; color: var(--color); box-shadow: var(--box-shadow); contain: strict; cursor: pointer; overflow: hidden; z-index: 0; appearance: none; box-sizing: border-box; } @supports (margin-inline-start: 0) or (-webkit-margin-start: 0) { .button-native { padding-left: unset; padding-right: unset; -webkit-padding-start: var(--padding-start); padding-inline-start: var(--padding-start); -webkit-padding-end: var(--padding-end); padding-inline-end: var(--padding-end); } } ::slotted(ion-icon) { line-height: 1; } .button-inner { left: 0; right: 0; top: 0; display: flex; position: absolute; flex-flow: row nowrap; flex-shrink: 0; align-items: center; justify-content: center; height: 100%; transition: all ease-in-out 300ms; transition-property: transform, opacity; } :host(.activated) .button-native { background: var(--background-activated); color: var(--color-activated); } :host(.ion-focused) .button-native { background: var(--background-focused); color: var(--color-focused); } :host(.fab-button-disabled) { pointer-events: none; } :host(.fab-button-disabled) .button-native { cursor: default; opacity: .5; pointer-events: none; } ::slotted(ion-icon) { line-height: 1; } :host(.fab-button-small) { margin-left: 8px; margin-right: 8px; margin-top: 8px; margin-bottom: 8px; width: 40px; height: 40px; } @supports (margin-inline-start: 0) or (-webkit-margin-start: 0) { :host(.fab-button-small) { margin-left: unset; margin-right: unset; -webkit-margin-start: 8px; margin-inline-start: 8px; -webkit-margin-end: 8px; margin-inline-end: 8px; } } .close-icon { left: 0; right: 0; top: 0; display: flex; position: absolute; align-items: center; justify-content: center; height: 100%; transform: scale(0.4) rotateZ(-45deg); transition: all ease-in-out 300ms; transition-property: transform, opacity; opacity: 0; } :host(.fab-button-close-active) .close-icon { transform: scale(1) rotateZ(0deg); opacity: 1; } :host(.fab-button-close-active) .button-inner { transform: scale(0.4) rotateZ(45deg); opacity: 0; } ion-ripple-effect { color: var(--ripple-color); } :host { --background: var(--ion-color-primary, #3880ff); --background-activated: var(--ion-color-primary-shade, #3171e0); --background-focused: var(--background-activated); --color: var(--ion-color-primary-contrast, #fff); --color-activated: var(--ion-color-primary-contrast, #fff); --color-focused: var(--color-activated); --box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12); --transition: 0.2s transform cubic-bezier(0.25, 1.11, 0.78, 1.59); } :host(.activated) { --box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12); --transform: scale(1.1); --transition: 0.2s transform ease-out; } ::slotted(ion-icon), .close-icon { font-size: 28px; } :host(.fab-button-in-list) { --background: var(--ion-color-light, #f4f5f8); --background-activated: var(--ion-color-light-shade, #d7d8da); --background-focused: var(--background-activated); --color: var(--ion-color-light-contrast, #000); --color-activated: var(--ion-color-light-contrast, #000); --color-focused: var(--color-activated); --transition: transform 200ms ease 10ms, opacity 200ms ease 10ms; } :host(.fab-button-in-list) ::slotted(ion-icon) { font-size: 18px; } :host(.fab-button-translucent) { --background: rgba(var(--ion-color-primary-rgb, 56, 128, 255), 0.9); --backdrop-filter: saturate(180%) blur(20px); } :host(.fab-button-translucent-in-list) { --background: rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8); } :host(.ion-color.fab-button-translucent) .button-native { background: rgba(var(--ion-color-base-rgb), 0.9); } :host(.ion-color.ion-focused.fab-button-translucent) .button-native, :host(.ion-color.activated.fab-button-translucent) .button-native { background: var(--ion-color-base); }