/*! * (C) Ionic http://ionicframework.com - MIT License */ import{r as t,h as e,H as i,f as a}from"./p-f419feca.js";import{a as n,c as o}from"./p-1b3ffb2f.js";import{a as s}from"./p-06fee233.js";import{c as r}from"./p-47794def.js";import{b as d}from"./p-2389b3f9.js";import{s as l,x as c,L as m,N as p,M as h}from"./p-3789920e.js";const u=class{constructor(e){t(this,e),this.datetimeEl=null,this.overlayEl=null,this.getParsedDateValues=t=>null==t?[]:Array.isArray(t)?t:[t],this.setDateTimeText=()=>{var t,e,i,a,n;const{datetimeEl:o,datetimePresentation:r}=this;if(!o)return;const{value:d,locale:u,formatOptions:b,hourCycle:f,preferWheel:v,multiple:x,titleSelectedDatesFormatter:g}=o,y=this.getParsedDateValues(d),w=l(y.length>0?y:[c()]);if(!w)return;const k=w[0],j=m(u,f);switch(this.dateText=this.timeText=void 0,r){case"date-time":case"time-date":const o=p(u,k,null!==(t=null==b?void 0:b.date)&&void 0!==t?t:{month:"short",day:"numeric",year:"numeric"}),r=h(u,k,j,null==b?void 0:b.time);v?this.dateText=`${o} ${r}`:(this.dateText=o,this.timeText=r);break;case"date":if(x&&1!==y.length){let t=`${y.length} days`;if(void 0!==g)try{t=g(y)}catch(t){s("Exception in provided `titleSelectedDatesFormatter`: ",t)}this.dateText=t}else this.dateText=p(u,k,null!==(e=null==b?void 0:b.date)&&void 0!==e?e:{month:"short",day:"numeric",year:"numeric"});break;case"time":this.timeText=h(u,k,j,null==b?void 0:b.time);break;case"month-year":this.dateText=p(u,k,null!==(i=null==b?void 0:b.date)&&void 0!==i?i:{month:"long",year:"numeric"});break;case"month":this.dateText=p(u,k,null!==(a=null==b?void 0:b.time)&&void 0!==a?a:{month:"long"});break;case"year":this.dateText=p(u,k,null!==(n=null==b?void 0:b.time)&&void 0!==n?n:{year:"numeric"})}},this.waitForDatetimeChanges=async()=>{const{datetimeEl:t}=this;return t?new Promise((e=>{n(t,"ionRender",e,{once:!0})})):Promise.resolve()},this.handleDateClick=async t=>{const{datetimeEl:e,datetimePresentation:i}=this;if(!e)return;let a=!1;switch(i){case"date-time":case"time-date":!e.preferWheel&&"date"!==e.presentation&&(e.presentation="date",a=!0)}this.selectedButton="date",this.presentOverlay(t,a,this.dateTargetEl)},this.handleTimeClick=t=>{const{datetimeEl:e,datetimePresentation:i}=this;if(!e)return;let a=!1;switch(i){case"date-time":case"time-date":"time"!==e.presentation&&(e.presentation="time",a=!0)}this.selectedButton="time",this.presentOverlay(t,a,this.timeTargetEl)},this.presentOverlay=async(t,e,i)=>{const{overlayEl:a}=this;a&&("ION-POPOVER"===a.tagName?(e&&await this.waitForDatetimeChanges(),a.present(Object.assign(Object.assign({},t),{detail:{ionShadowTarget:i}}))):a.present())},this.datetimePresentation="date-time",this.dateText=void 0,this.timeText=void 0,this.datetimeActive=!1,this.selectedButton=void 0,this.color="primary",this.disabled=!1,this.datetime=void 0}async componentWillLoad(){const{datetime:t}=this;if(!t)return void s("An ID associated with an ion-datetime instance is required for ion-datetime-button to function properly.",this.el);const e=this.datetimeEl=document.getElementById(t);if(!e)return void s(`No ion-datetime instance found for ID '${t}'.`,this.el);if("ION-DATETIME"!==e.tagName)return void s(`Expected an ion-datetime instance for ID '${t}' but received '${e.tagName.toLowerCase()}' instead.`,e);new IntersectionObserver((t=>{this.datetimeActive=t[0].isIntersecting}),{threshold:.01}).observe(e);const i=this.overlayEl=e.closest("ion-modal, ion-popover");i&&i.classList.add("ion-datetime-button-overlay"),o(e,(()=>{const t=this.datetimePresentation=e.presentation||"date-time";switch(this.setDateTimeText(),n(e,"ionValueChange",this.setDateTimeText),t){case"date-time":case"date":case"month-year":case"month":case"year":this.selectedButton="date";break;case"time-date":case"time":this.selectedButton="time"}}))}render(){const{color:t,dateText:a,timeText:n,selectedButton:o,datetimeActive:s,disabled:l}=this,c=d(this);return e(i,{key:"a38773e24ea0a28315be89baf0ef97f564b5d74b",class:r(t,{[c]:!0,[`${o}-active`]:s,"datetime-button-disabled":l})},a&&e("button",{class:"ion-activatable",id:"date-button","aria-expanded":s?"true":"false",onClick:this.handleDateClick,disabled:l,part:"native",ref:t=>this.dateTargetEl=t},e("slot",{name:"date-target"},a),"md"===c&&e("ion-ripple-effect",null)),n&&e("button",{class:"ion-activatable",id:"time-button","aria-expanded":s?"true":"false",onClick:this.handleTimeClick,disabled:l,part:"native",ref:t=>this.timeTargetEl=t},e("slot",{name:"time-target"},n),"md"===c&&e("ion-ripple-effect",null)))}get el(){return a(this)}};u.style={ios:":host{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}:host button{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;margin-top:0px;margin-bottom:0px;position:relative;-webkit-transition:150ms color ease-in-out;transition:150ms color ease-in-out;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:1rem;cursor:pointer;overflow:hidden;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.time-active) #time-button,:host(.date-active) #date-button{color:var(--ion-color-base)}:host(.datetime-button-disabled){pointer-events:none}:host(.datetime-button-disabled) button{opacity:0.4}",md:":host{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}:host button{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;margin-top:0px;margin-bottom:0px;position:relative;-webkit-transition:150ms color ease-in-out;transition:150ms color ease-in-out;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:1rem;cursor:pointer;overflow:hidden;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.time-active) #time-button,:host(.date-active) #date-button{color:var(--ion-color-base)}:host(.datetime-button-disabled){pointer-events:none}:host(.datetime-button-disabled) button{opacity:0.4}"};export{u as ion_datetime_button}