diff --git a/css/main.css b/css/main.css index 05abce0..4036f02 100644 --- a/css/main.css +++ b/css/main.css @@ -25,7 +25,6 @@ body { scrollbar-gutter: stable; color: rgba(var(--text-color), 1); background-color: rgba(var(--background-color), 1); - transition: background-color 0.3s; --dark-red: #d40e1e; --red: #f50000; --kinda-pink: #e40273; @@ -608,7 +607,6 @@ h3 { height: 100%; width: 100%; background-color: rgba(var(--foreground-color), 1); - transition: background-color 0.3s; } #pages_container { @@ -647,10 +645,7 @@ h3 { border-radius: 0.3rem; text-align: center; } -.nav-item .icon { - transition: transform 0.2s; -} -.nav-item__title { +.nav-item .icon, .nav-item__title { transition: opacity 0.2s, transform 0.2s; } .nav-item--active { @@ -667,6 +662,11 @@ h3 { background: var(--accent-color); border-radius: 1rem 1rem 0 0; z-index: 1; + view-transition-name: indicator; +} + +::view-transition { + transition: 0.3s; } #fix_invalid_button { @@ -1261,6 +1261,9 @@ legend, width: calc(100vw - 2rem); flex-wrap: wrap; } + #pagination_wrapper:empty { + display: none !important; + } } @media screen and (min-width: 40rem) { sm-popup { diff --git a/css/main.min.css b/css/main.min.css index f547e4f..ec66434 100644 --- a/css/main.min.css +++ b/css/main.min.css @@ -1 +1 @@ -*{padding:0;margin:0;box-sizing:border-box;font-family:"Roboto",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #256eff;--text-color: 20, 20, 20;--background-color: 240, 240, 240;--foreground-color: 250, 250, 250;--danger-color: rgb(255, 75, 75);--green: #1cad59;scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--background-color), 1);transition:background-color .3s;--dark-red: #d40e1e;--red: #f50000;--kinda-pink: #e40273;--purple: #462191;--shady-blue: #324de6;--nice-blue: #256eff;--maybe-cyan: #00b0ff;--teal: #00bcd4;--mint-green: #16c79a;--yellowish-green: #66bb6a;--greenish-yellow: #8bc34a;--dark-teal: #11698e;--tangerine: #ff6f00;--orange: #ff9100;--redish-orange: #ff3d00}body[data-theme=dark]{--accent-color: #86afff;--text-color: 220, 220, 220;--background-color: 10, 10, 10;--foreground-color: 24, 24, 24;--danger-color: rgb(255, 106, 106);--green: #00e676;--dark-red: #ff5e7e;--red: #ff6098;--kinda-pink: #c44ae6;--purple: #9565f7;--shady-blue: #7084f5;--nice-blue: #86afff;--maybe-cyan: #66cfff;--teal: #6aeeff;--mint-green: #4dffd2;--yellowish-green: #9effa2;--greenish-yellow: #c7fc8b;--dark-teal: #51cbff;--tangerine: #ffac6d;--orange: #ffbe68;--redish-orange: #ff8560}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}body[data-theme=dark] ::-webkit-calendar-picker-indicator{filter:invert(1)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}p:not(:last-of-type),strong:not(:last-of-type){margin-bottom:1.5rem}a{text-decoration:none;color:var(--accent-color)}a:focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}button,.button{-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:rgba(0,0,0,0);overflow:hidden;color:inherit;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:inherit;font-weight:500;white-space:nowrap;padding:.9rem;border-radius:.3rem;justify-content:center}button:focus-visible,.button:focus-visible{outline:var(--accent-color) solid medium}button:not(:disabled),.button:not(:disabled){cursor:pointer}.button{background-color:rgba(var(--text-color), 0.02);border:solid thin rgba(var(--text-color), 0.06)}.button--primary{color:rgba(var(--background-color), 1);background-color:var(--accent-color)}.button--primary .icon{fill:rgba(var(--background-color), 1)}.button--colored{color:var(--accent-color)}.button--colored .icon{fill:var(--accent-color)}.button--danger{background-color:rgba(255,115,115,.062745098);color:var(--danger-color)}.button--danger .icon{fill:var(--danger-color)}.button--small{padding:.4rem .6rem}.button--outlined{border:solid rgba(var(--text-color), 0.3) .1rem;background-color:rgba(var(--foreground-color), 1)}.button--transparent{background-color:rgba(0,0,0,0)}button:disabled{opacity:.4;cursor:not-allowed;filter:saturate(0)}.cta{text-transform:uppercase;font-size:.9rem;font-weight:700;letter-spacing:.05em;padding:.8rem 1rem}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.icon-only{padding:.5rem;border-radius:.3rem}.icon--big{width:3rem;height:3rem}a:-webkit-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:-moz-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}details{padding:1rem 0}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;justify-content:space-between;color:var(--accent-color)}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{font-size:.9rem;--border-radius: 0.5rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-textarea{--max-height: auto}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-chips{--gap: 0.3rem}sm-chip{position:relative;font-size:.9rem;--border-radius: 0.5rem;--padding: 0.5rem 0.8rem;--background: rgba(var(--text-color), 0.06);-webkit-user-select:none;-moz-user-select:none;user-select:none}sm-chip[selected]{--background: var(--accent-color);color:rgba(var(--background-color), 1)}sm-select::part(options){max-height:40vh}sm-option{flex-shrink:0}sm-option::part(option){grid-template-columns:none}ul{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.breakable{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.full-bleed{grid-column:1/-1}.h1{font-size:1.5rem}.h2{font-size:1.2rem}h3{font-size:1.2rem;line-height:1.3}.h4{font-size:.9rem}.h5{font-size:.75rem}.uppercase{text-transform:uppercase}.capitalize::first-letter{text-transform:uppercase}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-3{gap:.3rem}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-content:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.align-content-center{align-content:center}.text-center{text-align:center}.justify-start{justify-content:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.justify-items-center{justify-items:center}.align-self-center{align-self:center}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.h-100{height:100%}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-right-0-5{margin-right:.5rem}.margin-right-auto{margin-right:auto}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0)}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none !important}.observe-empty-state:not(:empty)+.empty-state{display:none}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:.5rem}#confirmation_popup .flex,#prompt_popup .flex{margin-top:1rem}.popup__header{position:relative;display:grid;gap:.5rem;width:100%;padding:0 1.5rem;align-items:center}.popup__header>*{grid-row:1}.popup__header h3,.popup__header h4{grid-column:1/-1;justify-self:center;align-self:center}.popup__header__close{grid-column:1;margin-left:-1rem;justify-self:flex-start}#loader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(var(--foreground-color), 1);z-index:100;display:grid;place-content:center;place-items:center;gap:1rem;text-align:center}#show_character_count{font-size:.8rem;margin-left:auto}#flo_data_status:not(:empty){color:red;padding:.5rem 0}#saved_ids_popup{--height: 80vh}#main_header{padding:.6rem 1rem}.app-brand{display:flex;gap:.3rem;align-items:center}.app-brand .icon{height:1.7rem;width:1.7rem}.app-name__company{font-size:.8rem;font-weight:500;color:rgba(var(--text-color), 0.8)}#main_card{display:flex;flex-direction:column;height:100%;width:100%;background-color:rgba(var(--foreground-color), 1);transition:background-color .3s}#pages_container{flex:1;overflow-y:auto}#main_navbar{display:flex;background:rgba(var(--text-color), 0.03)}#main_navbar.hide-away{position:absolute}#main_navbar ul{display:flex;height:100%;width:100%}#main_navbar ul li{width:100%}.nav-item{position:relative;display:flex;flex:1;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .3rem;color:var(--text-color);font-size:.7rem;border-radius:.3rem;text-align:center}.nav-item .icon{transition:transform .2s}.nav-item__title{transition:opacity .2s,transform .2s}.nav-item--active{color:var(--accent-color)}.nav-item--active .icon{fill:var(--accent-color)}.nav-item__indicator{position:absolute;bottom:0;width:2rem;height:.3rem;background:var(--accent-color);border-radius:1rem 1rem 0 0;z-index:1}#fix_invalid_button{margin-bottom:1rem !important}.password-field label{display:flex}.password-field label input:checked~.visible{display:none}.password-field label input:not(:checked)~.invisible{display:none}.multi-state-button{display:grid;text-align:center;align-items:center;justify-items:center}.multi-state-button>*{grid-area:1/1/2/2}.multi-state-button button{z-index:1;width:100%}.clip{-webkit-clip-path:circle(0);clip-path:circle(0)}#flo_id_warning{padding-bottom:1.5rem;border-bottom:thin solid rgba(var(--text-color), 0.3)}#flo_id_warning .icon{height:4rem;width:4rem;padding:1rem;background-color:#ffc107;border-radius:3rem;fill:rgba(0,0,0,.8);margin-bottom:1.5rem}.generated-id-card{display:grid;gap:1rem}.generated-id-card h5{margin-bottom:.3rem}#contacts>:first-child{overflow-y:auto;align-content:flex-start;padding-bottom:4rem}#primary_actions_wrapper{display:grid;gap:.5rem}.primary-action{display:flex;padding:.8rem 1rem;gap:.5rem;white-space:normal;font-size:.85rem;border-radius:.5rem;background-color:rgba(0,0,0,0);border:thin solid rgba(var(--text-color), 0.3);text-align:left}.primary-action .icon{fill:var(--accent-color)}#search{position:relative;height:100%}#queried_flo_address h4{font-size:1.1rem}#queried_flo_address>sm-copy{font-size:.8rem}#token_list{display:flex;flex-wrap:wrap;gap:.5rem}.token-item{font-size:.9rem;padding:.5rem 1rem;background-color:rgba(var(--text-color), 0.06);border-radius:.3rem}.transaction{gap:1.2rem;padding:1rem;background-color:rgba(var(--text-color), 0.03);border-radius:.3rem;content-visibility:auto;contain-intrinsic-size:10rem}.transaction:not(:last-of-type){margin-bottom:1rem}.transaction .icon{fill:var(--accent-color)}.transaction__time,.transaction__link,.transaction__receiver{font-size:.8rem}.transaction__receiver{margin-left:.5rem;color:rgba(var(--text-color), 0.9);font-weight:500}.transaction__receiver:hover{color:var(--accent-color)}.transaction__amount{font-weight:700}.transaction.mined .transaction__icon .icon,.transaction.received .transaction__icon .icon,.transaction.self .transaction__icon .icon{fill:var(--green)}.transaction.mined .transaction__amount,.transaction.received .transaction__amount,.transaction.self .transaction__amount{color:var(--green)}.transaction.mined .transaction__amount::before,.transaction.received .transaction__amount::before,.transaction.self .transaction__amount::before{content:"+ "}.transaction.sent .transaction__icon .icon{fill:var(--danger-color)}.transaction.sent .transaction__amount{color:var(--danger-color)}.transaction.sent .transaction__amount::before{content:"- "}.transaction p{font-size:.9rem;max-width:unset}.transaction__time{justify-self:flex-end;color:rgba(var(--text-color), 0.8)}#search_wrapper{width:min(100%,36rem)}#search_query_input{justify-self:center}#saved_ids_list{position:relative;align-content:flex-start;padding-bottom:1.5rem;margin-top:1rem;gap:1rem;grid-template-columns:repeat(auto-fill, minmax(16rem, 1fr))}.saved-id{grid-template-columns:auto 1fr;gap:0 .8rem;border-radius:.3rem;padding:.5rem;background-color:rgba(var(--text-color), 0.03);-webkit-user-select:none;-moz-user-select:none;user-select:none}.saved-id.highlight{box-shadow:0 0 .1rem .1rem var(--accent-color) inset}.saved-id .edit-saved{grid-area:1/1/3/2;padding:.3rem;position:relative}.saved-id .edit-saved .icon{position:absolute;height:1.2rem;width:1.2rem;right:0;bottom:0;border-radius:.5rem;padding:.2rem;background-color:rgba(var(--background-color), 1)}.saved-id__initial{display:flex;align-items:center;justify-content:center;height:2.4rem;width:2.4rem;font-size:1.2rem;text-transform:uppercase;color:rgba(var(--background-color), 1);font-weight:700;line-height:1;background-color:var(--accent-color);justify-self:flex-start;border-radius:2rem}.saved-id__label{align-self:flex-end}.saved-id__flo-id{font-size:.8rem}.page{position:relative;display:flex;flex-direction:column;overflow-y:auto;align-content:flex-start;padding:0 1rem;padding-bottom:3rem}.fab{position:absolute;right:0;bottom:0;margin:1.5rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);z-index:2}#add_address_button{border-radius:.5rem;color:rgba(var(--background-color), 1);background-color:var(--accent-color)}#add_address_button .icon{fill:rgba(var(--background-color), 1)}#balance_card{display:flex;flex-direction:column;gap:2rem;padding:max(1rem,2vw);background-color:rgba(var(--text-color), 0.06);aspect-ratio:4/2;justify-content:flex-end;border-radius:.5rem}#balance_card form{margin-top:1rem}#balance_card fieldset{border:none}.token-balance{display:flex;align-items:center;cursor:pointer;gap:.5rem;background-color:rgba(var(--text-color), 0.06);padding:.8rem;border-radius:.3rem;font-size:.9rem}.token-balance span:first-of-type::first-letter{text-transform:capitalize}.token-balance input{height:1rem;width:1rem;accent-color:var(--accent-color)}.token-receiver-combo{border:solid thin rgba(var(--text-color), 0.2);padding:.5rem;border-radius:.8rem}.token-receiver-combo--removable{grid-template-columns:1fr auto;grid-template-areas:"receiver receiver" "amount remove"}.token-receiver-combo--removable .token-receiver{grid-area:receiver}.token-receiver-combo--removable .token-amount{grid-area:amount}.token-receiver-combo--removable .remove-token-receiver{grid-area:remove}#transaction_result{display:grid;gap:.5rem;height:max(40vh,24rem);align-items:center;justify-content:center;text-align:center;align-content:center}#transaction_result:empty{display:none}#transaction_result h3{text-align:center;width:100%}#transaction_result .icon{justify-self:center;height:4rem;width:4rem;border-radius:5rem;margin-bottom:1rem;-webkit-animation:popup 1s;animation:popup 1s}#transaction_result .icon--success{fill:rgba(var(--background-color), 1);padding:1rem;background-color:#0bbe56}#transaction_result .icon--failed{background-color:rgba(var(--text-color), 0.03);fill:var(--danger-color)}#transaction_result sm-copy{font-size:.8rem}@-webkit-keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}@keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}#queried_address_transactions{display:flex;flex-direction:column;padding-bottom:4rem}#pagination_wrapper{position:fixed;bottom:0;right:0;margin:0 auto;padding:.5rem;background-color:rgba(var(--foreground-color), 1);z-index:5;border-radius:.7rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);margin:.5rem}.pagination__item{display:flex;padding:.2rem .5rem;border-radius:.3rem}.pagination__item--active{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}legend,.label{font-size:.8rem;color:rgba(var(--text-color), 0.8)}#smartcontracts{display:grid;min-width:0;height:100%}#smartcontracts>*{grid-area:1/1}#smartcontracts fieldset{padding:.5rem;border-radius:.5rem;border:solid 1px rgba(var(--text-color), 0.3)}#smartcontracts fieldset legend{padding:0 .5rem}#smartcontracts label{padding:.3rem .5rem}#smartcontracts label:has(input:not(:disabled):not(:checked)){cursor:pointer}#smartcontracts input[type=radio]{height:1.1em;width:1.1em;margin-right:.5rem;accent-color:var(--accent-color)}#smartcontracts input[type=datetime-local]{width:100%;padding:.8rem .6rem;border:none;border-radius:.5rem;font-weight:500;font-family:inherit;font-size:inherit;color:inherit;background-color:rgba(var(--text-color), 0.06)}#smartcontracts input[type=datetime-local]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}#smartcontracts sm-input:not([placeholder]){--min-height: 3rem}.smart-contract-action{flex-direction:column;white-space:normal;gap:.5rem;color:rgba(var(--text-color), 0.8);width:5rem;font-size:.9rem;aspect-ratio:1/1;border-radius:.5rem;border:solid 1px rgba(var(--text-color), 0.3);text-align:center}.smart-contract-action .icon{fill:var(--accent-color)}#smart_contract_creation_templates{display:grid;gap:.5rem}#smart_contract_creation_templates li{display:flex;flex:1}.smart-contract-template{display:grid;grid-template-areas:"heading arrow" "description arrow";grid-template-columns:1fr auto;padding:max(1rem,2vw);border:solid 1px rgba(var(--text-color), 0.3);border-radius:.5rem;gap:.5rem;text-align:start;white-space:normal;width:100%;justify-content:flex-start}.smart-contract-template h4{grid-area:heading}.smart-contract-template p{grid-area:description;font-weight:400;line-height:1.3;font-size:.9rem;color:rgba(var(--text-color), 0.8);text-transform:none}.smart-contract-template .icon{margin-top:auto;grid-area:arrow;border:solid 1px rgba(var(--text-color), 0.3);border-radius:3rem;padding:.4rem;height:2rem;width:2rem;fill:var(--accent-color)}.payee-address-wrapper{display:grid;grid-template-columns:1fr auto;gap:.5rem}.payee-address-wrapper:first-of-type{grid-template-areas:"address" "share"}.payee-address-wrapper:not(:first-of-type){grid-template-areas:"address address" "share button"}.payee-address-wrapper .payee-address{grid-area:address}.payee-address-wrapper .payee-share{grid-area:share}.payee-address-wrapper .icon-only{grid-area:button}.payee-address-wrapper .icon-only{height:3.18rem}.choice-wrapper{display:grid;grid-template-columns:1fr auto;gap:.5rem}.choice-wrapper .icon-only{aspect-ratio:1/1;height:3.18rem}@media screen and (max-width: 40rem){#main_navbar.hide-away{bottom:0;left:0;right:0}#primary_actions_wrapper{grid-template-columns:1fr 1fr}.nav-item__title{margin-top:.3rem}.nav-item--active .icon{transform:translateY(50%)}.nav-item--active .nav-item__title{transform:translateY(100%);opacity:0}#pagination_wrapper{margin:0;margin-bottom:4.8rem;left:50%;right:auto;transform:translateX(-50%);width:calc(100vw - 2rem);flex-wrap:wrap}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}.popup__header{padding:1rem 1.5rem 0 1.5rem}body{display:flex;align-items:center;justify-content:center}#main_card{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto 1fr;grid-template-areas:"header header" "nav main";position:relative}#main_header{grid-area:header}#pages_container{grid-area:main}.page{padding:0 1.5rem}#main_navbar{grid-area:nav;border-top:none;flex-direction:column;height:100%}#main_navbar ul{flex-direction:column}.nav-item{flex-direction:row;text-align:left;justify-content:flex-start;gap:.5rem;padding:1rem;font-weight:500;font-size:.8rem;border-radius:0;min-width:10rem}.nav-item__indicator{width:.25rem;height:50%;left:0;border-radius:0 1rem 1rem 0;bottom:auto}#primary_actions_wrapper{display:flex;flex-wrap:wrap}#create_flo_id_popup,#retrieve_flo_id_popup{--width: 26rem}#send{padding:0 6vw}#send sm-form{width:min(56rem,100%);margin:auto}#smart_contract_creation_templates{grid-template-columns:repeat(auto-fill, minmax(20rem, 1fr))}#smart_contract_deposit_form,#smart_contract_participate_form,#smart_contract_update_form,#smart_contract_trigger_form{width:min(36rem,100%);margin:auto;--gap: 1.5rem}#smart_contract_creation_form::part(form){gap:1.5rem;margin:auto;width:min(36rem,100%)}#smart_contract_creation_form::part(form).split-layout{grid-template-columns:1fr 1.5fr;align-items:flex-start;width:min(50rem,100%)}.payee-address-wrapper{display:grid;grid-template-columns:1fr 8rem 3rem}.payee-address-wrapper:first-of-type{grid-template-areas:"address share share"}.payee-address-wrapper:not(:first-of-type){grid-template-areas:"address share button"}}@media screen and (min-width: 56rem){#send sm-form::part(form){align-items:flex-start;grid-template-columns:1fr 1.5fr}}@media screen and (min-width: 64rem){#address_details_wrapper{grid-template-columns:auto 1fr;align-items:flex-start}#transactions_hero_section{position:-webkit-sticky;position:sticky;top:0}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.interact:not([disabled]){transition:background-color .3s}.interact:not([disabled]):hover{background-color:rgba(var(--text-color), 0.06)}.button:not([disabled]){transition:background-color .3s,filter .3s}.button:not([disabled]):hover{filter:contrast(2)}}@supports(overflow: overlay){body{overflow:overlay}}.hidden{display:none !important} \ No newline at end of file +*{padding:0;margin:0;box-sizing:border-box;font-family:"Roboto",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #256eff;--text-color: 20, 20, 20;--background-color: 240, 240, 240;--foreground-color: 250, 250, 250;--danger-color: rgb(255, 75, 75);--green: #1cad59;scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--background-color), 1);--dark-red: #d40e1e;--red: #f50000;--kinda-pink: #e40273;--purple: #462191;--shady-blue: #324de6;--nice-blue: #256eff;--maybe-cyan: #00b0ff;--teal: #00bcd4;--mint-green: #16c79a;--yellowish-green: #66bb6a;--greenish-yellow: #8bc34a;--dark-teal: #11698e;--tangerine: #ff6f00;--orange: #ff9100;--redish-orange: #ff3d00}body[data-theme=dark]{--accent-color: #86afff;--text-color: 220, 220, 220;--background-color: 10, 10, 10;--foreground-color: 24, 24, 24;--danger-color: rgb(255, 106, 106);--green: #00e676;--dark-red: #ff5e7e;--red: #ff6098;--kinda-pink: #c44ae6;--purple: #9565f7;--shady-blue: #7084f5;--nice-blue: #86afff;--maybe-cyan: #66cfff;--teal: #6aeeff;--mint-green: #4dffd2;--yellowish-green: #9effa2;--greenish-yellow: #c7fc8b;--dark-teal: #51cbff;--tangerine: #ffac6d;--orange: #ffbe68;--redish-orange: #ff8560}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}body[data-theme=dark] ::-webkit-calendar-picker-indicator{filter:invert(1)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}p:not(:last-of-type),strong:not(:last-of-type){margin-bottom:1.5rem}a{text-decoration:none;color:var(--accent-color)}a:focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}button,.button{-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:rgba(0,0,0,0);overflow:hidden;color:inherit;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:inherit;font-weight:500;white-space:nowrap;padding:.9rem;border-radius:.3rem;justify-content:center}button:focus-visible,.button:focus-visible{outline:var(--accent-color) solid medium}button:not(:disabled),.button:not(:disabled){cursor:pointer}.button{background-color:rgba(var(--text-color), 0.02);border:solid thin rgba(var(--text-color), 0.06)}.button--primary{color:rgba(var(--background-color), 1);background-color:var(--accent-color)}.button--primary .icon{fill:rgba(var(--background-color), 1)}.button--colored{color:var(--accent-color)}.button--colored .icon{fill:var(--accent-color)}.button--danger{background-color:rgba(255,115,115,.062745098);color:var(--danger-color)}.button--danger .icon{fill:var(--danger-color)}.button--small{padding:.4rem .6rem}.button--outlined{border:solid rgba(var(--text-color), 0.3) .1rem;background-color:rgba(var(--foreground-color), 1)}.button--transparent{background-color:rgba(0,0,0,0)}button:disabled{opacity:.4;cursor:not-allowed;filter:saturate(0)}.cta{text-transform:uppercase;font-size:.9rem;font-weight:700;letter-spacing:.05em;padding:.8rem 1rem}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.icon-only{padding:.5rem;border-radius:.3rem}.icon--big{width:3rem;height:3rem}a:-webkit-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:-moz-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}details{padding:1rem 0}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;justify-content:space-between;color:var(--accent-color)}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{font-size:.9rem;--border-radius: 0.5rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-textarea{--max-height: auto}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-chips{--gap: 0.3rem}sm-chip{position:relative;font-size:.9rem;--border-radius: 0.5rem;--padding: 0.5rem 0.8rem;--background: rgba(var(--text-color), 0.06);-webkit-user-select:none;-moz-user-select:none;user-select:none}sm-chip[selected]{--background: var(--accent-color);color:rgba(var(--background-color), 1)}sm-select::part(options){max-height:40vh}sm-option{flex-shrink:0}sm-option::part(option){grid-template-columns:none}ul{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.breakable{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.full-bleed{grid-column:1/-1}.h1{font-size:1.5rem}.h2{font-size:1.2rem}h3{font-size:1.2rem;line-height:1.3}.h4{font-size:.9rem}.h5{font-size:.75rem}.uppercase{text-transform:uppercase}.capitalize::first-letter{text-transform:uppercase}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-3{gap:.3rem}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-content:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.align-content-center{align-content:center}.text-center{text-align:center}.justify-start{justify-content:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.justify-items-center{justify-items:center}.align-self-center{align-self:center}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.h-100{height:100%}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-right-0-5{margin-right:.5rem}.margin-right-auto{margin-right:auto}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0)}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none !important}.observe-empty-state:not(:empty)+.empty-state{display:none}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:.5rem}#confirmation_popup .flex,#prompt_popup .flex{margin-top:1rem}.popup__header{position:relative;display:grid;gap:.5rem;width:100%;padding:0 1.5rem;align-items:center}.popup__header>*{grid-row:1}.popup__header h3,.popup__header h4{grid-column:1/-1;justify-self:center;align-self:center}.popup__header__close{grid-column:1;margin-left:-1rem;justify-self:flex-start}#loader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(var(--foreground-color), 1);z-index:100;display:grid;place-content:center;place-items:center;gap:1rem;text-align:center}#show_character_count{font-size:.8rem;margin-left:auto}#flo_data_status:not(:empty){color:red;padding:.5rem 0}#saved_ids_popup{--height: 80vh}#main_header{padding:.6rem 1rem}.app-brand{display:flex;gap:.3rem;align-items:center}.app-brand .icon{height:1.7rem;width:1.7rem}.app-name__company{font-size:.8rem;font-weight:500;color:rgba(var(--text-color), 0.8)}#main_card{display:flex;flex-direction:column;height:100%;width:100%;background-color:rgba(var(--foreground-color), 1)}#pages_container{flex:1;overflow-y:auto}#main_navbar{display:flex;background:rgba(var(--text-color), 0.03)}#main_navbar.hide-away{position:absolute}#main_navbar ul{display:flex;height:100%;width:100%}#main_navbar ul li{width:100%}.nav-item{position:relative;display:flex;flex:1;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .3rem;color:var(--text-color);font-size:.7rem;border-radius:.3rem;text-align:center}.nav-item .icon,.nav-item__title{transition:opacity .2s,transform .2s}.nav-item--active{color:var(--accent-color)}.nav-item--active .icon{fill:var(--accent-color)}.nav-item__indicator{position:absolute;bottom:0;width:2rem;height:.3rem;background:var(--accent-color);border-radius:1rem 1rem 0 0;z-index:1;view-transition-name:indicator}::view-transition{transition:.3s}#fix_invalid_button{margin-bottom:1rem !important}.password-field label{display:flex}.password-field label input:checked~.visible{display:none}.password-field label input:not(:checked)~.invisible{display:none}.multi-state-button{display:grid;text-align:center;align-items:center;justify-items:center}.multi-state-button>*{grid-area:1/1/2/2}.multi-state-button button{z-index:1;width:100%}.clip{-webkit-clip-path:circle(0);clip-path:circle(0)}#flo_id_warning{padding-bottom:1.5rem;border-bottom:thin solid rgba(var(--text-color), 0.3)}#flo_id_warning .icon{height:4rem;width:4rem;padding:1rem;background-color:#ffc107;border-radius:3rem;fill:rgba(0,0,0,.8);margin-bottom:1.5rem}.generated-id-card{display:grid;gap:1rem}.generated-id-card h5{margin-bottom:.3rem}#contacts>:first-child{overflow-y:auto;align-content:flex-start;padding-bottom:4rem}#primary_actions_wrapper{display:grid;gap:.5rem}.primary-action{display:flex;padding:.8rem 1rem;gap:.5rem;white-space:normal;font-size:.85rem;border-radius:.5rem;background-color:rgba(0,0,0,0);border:thin solid rgba(var(--text-color), 0.3);text-align:left}.primary-action .icon{fill:var(--accent-color)}#search{position:relative;height:100%}#queried_flo_address h4{font-size:1.1rem}#queried_flo_address>sm-copy{font-size:.8rem}#token_list{display:flex;flex-wrap:wrap;gap:.5rem}.token-item{font-size:.9rem;padding:.5rem 1rem;background-color:rgba(var(--text-color), 0.06);border-radius:.3rem}.transaction{gap:1.2rem;padding:1rem;background-color:rgba(var(--text-color), 0.03);border-radius:.3rem;content-visibility:auto;contain-intrinsic-size:10rem}.transaction:not(:last-of-type){margin-bottom:1rem}.transaction .icon{fill:var(--accent-color)}.transaction__time,.transaction__link,.transaction__receiver{font-size:.8rem}.transaction__receiver{margin-left:.5rem;color:rgba(var(--text-color), 0.9);font-weight:500}.transaction__receiver:hover{color:var(--accent-color)}.transaction__amount{font-weight:700}.transaction.mined .transaction__icon .icon,.transaction.received .transaction__icon .icon,.transaction.self .transaction__icon .icon{fill:var(--green)}.transaction.mined .transaction__amount,.transaction.received .transaction__amount,.transaction.self .transaction__amount{color:var(--green)}.transaction.mined .transaction__amount::before,.transaction.received .transaction__amount::before,.transaction.self .transaction__amount::before{content:"+ "}.transaction.sent .transaction__icon .icon{fill:var(--danger-color)}.transaction.sent .transaction__amount{color:var(--danger-color)}.transaction.sent .transaction__amount::before{content:"- "}.transaction p{font-size:.9rem;max-width:unset}.transaction__time{justify-self:flex-end;color:rgba(var(--text-color), 0.8)}#search_wrapper{width:min(100%,36rem)}#search_query_input{justify-self:center}#saved_ids_list{position:relative;align-content:flex-start;padding-bottom:1.5rem;margin-top:1rem;gap:1rem;grid-template-columns:repeat(auto-fill, minmax(16rem, 1fr))}.saved-id{grid-template-columns:auto 1fr;gap:0 .8rem;border-radius:.3rem;padding:.5rem;background-color:rgba(var(--text-color), 0.03);-webkit-user-select:none;-moz-user-select:none;user-select:none}.saved-id.highlight{box-shadow:0 0 .1rem .1rem var(--accent-color) inset}.saved-id .edit-saved{grid-area:1/1/3/2;padding:.3rem;position:relative}.saved-id .edit-saved .icon{position:absolute;height:1.2rem;width:1.2rem;right:0;bottom:0;border-radius:.5rem;padding:.2rem;background-color:rgba(var(--background-color), 1)}.saved-id__initial{display:flex;align-items:center;justify-content:center;height:2.4rem;width:2.4rem;font-size:1.2rem;text-transform:uppercase;color:rgba(var(--background-color), 1);font-weight:700;line-height:1;background-color:var(--accent-color);justify-self:flex-start;border-radius:2rem}.saved-id__label{align-self:flex-end}.saved-id__flo-id{font-size:.8rem}.page{position:relative;display:flex;flex-direction:column;overflow-y:auto;align-content:flex-start;padding:0 1rem;padding-bottom:3rem}.fab{position:absolute;right:0;bottom:0;margin:1.5rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);z-index:2}#add_address_button{border-radius:.5rem;color:rgba(var(--background-color), 1);background-color:var(--accent-color)}#add_address_button .icon{fill:rgba(var(--background-color), 1)}#balance_card{display:flex;flex-direction:column;gap:2rem;padding:max(1rem,2vw);background-color:rgba(var(--text-color), 0.06);aspect-ratio:4/2;justify-content:flex-end;border-radius:.5rem}#balance_card form{margin-top:1rem}#balance_card fieldset{border:none}.token-balance{display:flex;align-items:center;cursor:pointer;gap:.5rem;background-color:rgba(var(--text-color), 0.06);padding:.8rem;border-radius:.3rem;font-size:.9rem}.token-balance span:first-of-type::first-letter{text-transform:capitalize}.token-balance input{height:1rem;width:1rem;accent-color:var(--accent-color)}.token-receiver-combo{border:solid thin rgba(var(--text-color), 0.2);padding:.5rem;border-radius:.8rem}.token-receiver-combo--removable{grid-template-columns:1fr auto;grid-template-areas:"receiver receiver" "amount remove"}.token-receiver-combo--removable .token-receiver{grid-area:receiver}.token-receiver-combo--removable .token-amount{grid-area:amount}.token-receiver-combo--removable .remove-token-receiver{grid-area:remove}#transaction_result{display:grid;gap:.5rem;height:max(40vh,24rem);align-items:center;justify-content:center;text-align:center;align-content:center}#transaction_result:empty{display:none}#transaction_result h3{text-align:center;width:100%}#transaction_result .icon{justify-self:center;height:4rem;width:4rem;border-radius:5rem;margin-bottom:1rem;-webkit-animation:popup 1s;animation:popup 1s}#transaction_result .icon--success{fill:rgba(var(--background-color), 1);padding:1rem;background-color:#0bbe56}#transaction_result .icon--failed{background-color:rgba(var(--text-color), 0.03);fill:var(--danger-color)}#transaction_result sm-copy{font-size:.8rem}@-webkit-keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}@keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}#queried_address_transactions{display:flex;flex-direction:column;padding-bottom:4rem}#pagination_wrapper{position:fixed;bottom:0;right:0;margin:0 auto;padding:.5rem;background-color:rgba(var(--foreground-color), 1);z-index:5;border-radius:.7rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);margin:.5rem}.pagination__item{display:flex;padding:.2rem .5rem;border-radius:.3rem}.pagination__item--active{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}legend,.label{font-size:.8rem;color:rgba(var(--text-color), 0.8)}#smartcontracts{display:grid;min-width:0;height:100%}#smartcontracts>*{grid-area:1/1}#smartcontracts fieldset{padding:.5rem;border-radius:.5rem;border:solid 1px rgba(var(--text-color), 0.3)}#smartcontracts fieldset legend{padding:0 .5rem}#smartcontracts label{padding:.3rem .5rem}#smartcontracts label:has(input:not(:disabled):not(:checked)){cursor:pointer}#smartcontracts input[type=radio]{height:1.1em;width:1.1em;margin-right:.5rem;accent-color:var(--accent-color)}#smartcontracts input[type=datetime-local]{width:100%;padding:.8rem .6rem;border:none;border-radius:.5rem;font-weight:500;font-family:inherit;font-size:inherit;color:inherit;background-color:rgba(var(--text-color), 0.06)}#smartcontracts input[type=datetime-local]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}#smartcontracts sm-input:not([placeholder]){--min-height: 3rem}.smart-contract-action{flex-direction:column;white-space:normal;gap:.5rem;color:rgba(var(--text-color), 0.8);width:5rem;font-size:.9rem;aspect-ratio:1/1;border-radius:.5rem;border:solid 1px rgba(var(--text-color), 0.3);text-align:center}.smart-contract-action .icon{fill:var(--accent-color)}#smart_contract_creation_templates{display:grid;gap:.5rem}#smart_contract_creation_templates li{display:flex;flex:1}.smart-contract-template{display:grid;grid-template-areas:"heading arrow" "description arrow";grid-template-columns:1fr auto;padding:max(1rem,2vw);border:solid 1px rgba(var(--text-color), 0.3);border-radius:.5rem;gap:.5rem;text-align:start;white-space:normal;width:100%;justify-content:flex-start}.smart-contract-template h4{grid-area:heading}.smart-contract-template p{grid-area:description;font-weight:400;line-height:1.3;font-size:.9rem;color:rgba(var(--text-color), 0.8);text-transform:none}.smart-contract-template .icon{margin-top:auto;grid-area:arrow;border:solid 1px rgba(var(--text-color), 0.3);border-radius:3rem;padding:.4rem;height:2rem;width:2rem;fill:var(--accent-color)}.payee-address-wrapper{display:grid;grid-template-columns:1fr auto;gap:.5rem}.payee-address-wrapper:first-of-type{grid-template-areas:"address" "share"}.payee-address-wrapper:not(:first-of-type){grid-template-areas:"address address" "share button"}.payee-address-wrapper .payee-address{grid-area:address}.payee-address-wrapper .payee-share{grid-area:share}.payee-address-wrapper .icon-only{grid-area:button}.payee-address-wrapper .icon-only{height:3.18rem}.choice-wrapper{display:grid;grid-template-columns:1fr auto;gap:.5rem}.choice-wrapper .icon-only{aspect-ratio:1/1;height:3.18rem}@media screen and (max-width: 40rem){#main_navbar.hide-away{bottom:0;left:0;right:0}#primary_actions_wrapper{grid-template-columns:1fr 1fr}.nav-item__title{margin-top:.3rem}.nav-item--active .icon{transform:translateY(50%)}.nav-item--active .nav-item__title{transform:translateY(100%);opacity:0}#pagination_wrapper{margin:0;margin-bottom:4.8rem;left:50%;right:auto;transform:translateX(-50%);width:calc(100vw - 2rem);flex-wrap:wrap}#pagination_wrapper:empty{display:none !important}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}.popup__header{padding:1rem 1.5rem 0 1.5rem}body{display:flex;align-items:center;justify-content:center}#main_card{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto 1fr;grid-template-areas:"header header" "nav main";position:relative}#main_header{grid-area:header}#pages_container{grid-area:main}.page{padding:0 1.5rem}#main_navbar{grid-area:nav;border-top:none;flex-direction:column;height:100%}#main_navbar ul{flex-direction:column}.nav-item{flex-direction:row;text-align:left;justify-content:flex-start;gap:.5rem;padding:1rem;font-weight:500;font-size:.8rem;border-radius:0;min-width:10rem}.nav-item__indicator{width:.25rem;height:50%;left:0;border-radius:0 1rem 1rem 0;bottom:auto}#primary_actions_wrapper{display:flex;flex-wrap:wrap}#create_flo_id_popup,#retrieve_flo_id_popup{--width: 26rem}#send{padding:0 6vw}#send sm-form{width:min(56rem,100%);margin:auto}#smart_contract_creation_templates{grid-template-columns:repeat(auto-fill, minmax(20rem, 1fr))}#smart_contract_deposit_form,#smart_contract_participate_form,#smart_contract_update_form,#smart_contract_trigger_form{width:min(36rem,100%);margin:auto;--gap: 1.5rem}#smart_contract_creation_form::part(form){gap:1.5rem;margin:auto;width:min(36rem,100%)}#smart_contract_creation_form::part(form).split-layout{grid-template-columns:1fr 1.5fr;align-items:flex-start;width:min(50rem,100%)}.payee-address-wrapper{display:grid;grid-template-columns:1fr 8rem 3rem}.payee-address-wrapper:first-of-type{grid-template-areas:"address share share"}.payee-address-wrapper:not(:first-of-type){grid-template-areas:"address share button"}}@media screen and (min-width: 56rem){#send sm-form::part(form){align-items:flex-start;grid-template-columns:1fr 1.5fr}}@media screen and (min-width: 64rem){#address_details_wrapper{grid-template-columns:auto 1fr;align-items:flex-start}#transactions_hero_section{position:-webkit-sticky;position:sticky;top:0}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.interact:not([disabled]){transition:background-color .3s}.interact:not([disabled]):hover{background-color:rgba(var(--text-color), 0.06)}.button:not([disabled]){transition:background-color .3s,filter .3s}.button:not([disabled]):hover{filter:contrast(2)}}@supports(overflow: overlay){body{overflow:overlay}}.hidden{display:none !important} \ No newline at end of file diff --git a/css/main.scss b/css/main.scss index 0f5a98f..ef615ae 100644 --- a/css/main.scss +++ b/css/main.scss @@ -25,7 +25,6 @@ body { scrollbar-gutter: stable; color: rgba(var(--text-color), 1); background-color: rgba(var(--background-color), 1); - transition: background-color 0.3s; // Accent colors --dark-red: #d40e1e; --red: #f50000; @@ -580,7 +579,6 @@ h3 { height: 100%; width: 100%; background-color: rgba(var(--foreground-color), 1); - transition: background-color 0.3s; } #pages_container { flex: 1; @@ -616,9 +614,7 @@ h3 { font-size: 0.7rem; border-radius: 0.3rem; text-align: center; - .icon { - transition: transform 0.2s; - } + .icon, &__title { transition: opacity 0.2s, transform 0.2s; } @@ -636,8 +632,12 @@ h3 { background: var(--accent-color); border-radius: 1rem 1rem 0 0; z-index: 1; + view-transition-name: indicator; } } +::view-transition { + transition: 0.3s; +} #fix_invalid_button { margin-bottom: 1rem !important; @@ -1204,6 +1204,9 @@ legend, transform: translateX(-50%); width: calc(100vw - 2rem); flex-wrap: wrap; + &:empty { + display: none !important; + } } } @media screen and (min-width: 40rem) { diff --git a/index.html b/index.html index ee03a77..1cf7d89 100644 --- a/index.html +++ b/index.html @@ -54,7 +54,7 @@ routeTo(window.location.hash, { firstLoad: true }) }).catch(e => { console.error(e) - routeTo(window.location.hash, { firstLoad: true, smartContractUnavailable: true }) + routeTo(window.location.hash, { firstLoad: true, smartContractsUnavailable: true }) }).finally(() => { loader(false) }) @@ -204,7 +204,7 @@ class="button justify-self-center hidden">Load more -
+
@@ -1178,7 +1178,7 @@ let tempData async function routeTo(targetPage, options = {}) { - const { firstLoad, hashChange, smartContractUnavailable = false } = options + const { firstLoad, hashChange, smartContractsUnavailable = false } = options let pageId let params = {} let searchParams @@ -1475,100 +1475,129 @@ } break } - const animOptions = { - duration: 100, - fill: 'forwards', - } let previousActiveElement = getRef('main_navbar').querySelector('.nav-item--active') const currentActiveElement = document.querySelector(`.nav-item[href="#/${pageId}"]`) - if (currentActiveElement) { - if (getRef('main_navbar').classList.contains('hidden')) { - getRef('main_navbar').classList.remove('hide-away') - getRef('main_navbar').classList.remove('hidden') - getRef('main_navbar').animate([ - { - transform: isMobileView ? `translateY(100%)` : `translateX(-100%)`, - opacity: 0, - }, - { - transform: `none`, - opacity: 1, - }, - ], { - duration: 100, - fill: 'forwards', - easing: 'ease' - }) - } - getRef('main_header').classList.remove('hidden') - const previousActiveElementIndex = [...getRef('main_navbar').querySelectorAll('.nav-item')].indexOf(previousActiveElement) - const currentActiveElementIndex = [...getRef('main_navbar').querySelectorAll('.nav-item')].indexOf(currentActiveElement) - const isOnTop = previousActiveElementIndex < currentActiveElementIndex - const currentIndicator = createElement('div', { className: 'nav-item__indicator' }); - let previousIndicator = getRef('main_navbar').querySelector('.nav-item__indicator') - if (!previousIndicator) { - previousIndicator = currentIndicator.cloneNode(true) - previousActiveElement = currentActiveElement - previousActiveElement.append(previousIndicator) - } else if (currentActiveElementIndex !== previousActiveElementIndex) { - const indicatorDimensions = previousIndicator.getBoundingClientRect() - const currentActiveElementDimensions = currentActiveElement.getBoundingClientRect() - let moveBy - if (isMobileView) { - moveBy = ((currentActiveElementDimensions.width - indicatorDimensions.width) / 2) + indicatorDimensions.width + if (document.startViewTransition) { + document.startViewTransition(() => { + if (previousActiveElement) { + previousActiveElement.classList.remove('nav-item--active'); + previousActiveElement.querySelector('.nav-item__indicator')?.remove() + } + if (currentActiveElement) { + if (getRef('main_navbar').classList.contains('hidden')) { + getRef('main_navbar').classList.remove('hide-away') + getRef('main_navbar').classList.remove('hidden') + } + getRef('main_header').classList.remove('hidden') + currentActiveElement.classList.add('nav-item--active') + currentActiveElement.append(createElement('div', { className: 'nav-item__indicator' })); } else { - moveBy = ((currentActiveElementDimensions.height - indicatorDimensions.height) / 2) + indicatorDimensions.height + if (!getRef('main_navbar').classList.contains('hidden')) { + getRef('main_navbar').classList.add('hide-away') + getRef('main_navbar').classList.add('hidden') + getRef('main_header').classList.add('hidden') + } } - indicatorObserver.observe(previousIndicator) - previousIndicator.animate([ - { - transform: 'none', - opacity: 1, - }, - { - transform: `translate${isMobileView ? 'X' : 'Y'}(${isOnTop ? `${moveBy}px` : `-${moveBy}px`})`, - opacity: 0, - }, - ], { ...animOptions, easing: 'ease-in' }).onfinish = () => { - previousIndicator.remove() + if (pagesData.lastPage !== pageId) { + document.querySelectorAll('.page').forEach(page => page.classList.add('hidden')) + getRef(pageId).classList.remove('hidden') + pagesData.lastPage = pageId } - tempData = { - currentActiveElement, - currentIndicator, - isOnTop, - animOptions, - moveBy - } - } - previousActiveElement.classList.remove('nav-item--active'); - currentActiveElement.classList.add('nav-item--active') + }) } else { - if (!getRef('main_navbar').classList.contains('hidden')) { - getRef('main_navbar').classList.add('hide-away') - getRef('main_navbar').animate([ - { - transform: `none`, - opacity: 1, - }, - { - transform: isMobileView ? `translateY(100%)` : `translateX(-100%)`, - opacity: 0, - }, - ], { - duration: 200, - fill: 'forwards', - easing: 'ease' - }).onfinish = () => { - getRef('main_navbar').classList.add('hidden') - } - getRef('main_header').classList.add('hidden') + const animOptions = { + duration: 100, + fill: 'forwards', + } + if (currentActiveElement) { + if (getRef('main_navbar').classList.contains('hidden')) { + getRef('main_navbar').classList.remove('hide-away') + getRef('main_navbar').classList.remove('hidden') + getRef('main_navbar').animate([ + { + transform: isMobileView ? `translateY(100%)` : `translateX(-100%)`, + opacity: 0, + }, + { + transform: `none`, + opacity: 1, + }, + ], { + duration: 100, + fill: 'forwards', + easing: 'ease' + }) + } + getRef('main_header').classList.remove('hidden') + const previousActiveElementIndex = [...getRef('main_navbar').querySelectorAll('.nav-item')].indexOf(previousActiveElement) + const currentActiveElementIndex = [...getRef('main_navbar').querySelectorAll('.nav-item')].indexOf(currentActiveElement) + const isOnTop = previousActiveElementIndex < currentActiveElementIndex + const currentIndicator = createElement('div', { className: 'nav-item__indicator' }); + let previousIndicator = getRef('main_navbar').querySelector('.nav-item__indicator') + if (!previousIndicator) { + previousIndicator = currentIndicator.cloneNode(true) + previousActiveElement = currentActiveElement + previousActiveElement.append(previousIndicator) + } else if (currentActiveElementIndex !== previousActiveElementIndex) { + const indicatorDimensions = previousIndicator.getBoundingClientRect() + const currentActiveElementDimensions = currentActiveElement.getBoundingClientRect() + let moveBy + if (isMobileView) { + moveBy = ((currentActiveElementDimensions.width - indicatorDimensions.width) / 2) + indicatorDimensions.width + } else { + moveBy = ((currentActiveElementDimensions.height - indicatorDimensions.height) / 2) + indicatorDimensions.height + } + indicatorObserver.observe(previousIndicator) + previousIndicator.animate([ + { + transform: 'none', + opacity: 1, + }, + { + transform: `translate${isMobileView ? 'X' : 'Y'}(${isOnTop ? `${moveBy}px` : `-${moveBy}px`})`, + opacity: 0, + }, + ], { ...animOptions, easing: 'ease-in' }).onfinish = () => { + previousIndicator.remove() + } + tempData = { + currentActiveElement, + currentIndicator, + isOnTop, + animOptions, + moveBy + } + } + previousActiveElement.classList.remove('nav-item--active'); + currentActiveElement.classList.add('nav-item--active') + } else { + if (!getRef('main_navbar').classList.contains('hidden')) { + getRef('main_navbar').classList.add('hide-away') + getRef('main_navbar').animate([ + { + transform: `none`, + opacity: 1, + }, + { + transform: isMobileView ? `translateY(100%)` : `translateX(-100%)`, + opacity: 0, + }, + ], { + duration: 200, + fill: 'forwards', + easing: 'ease' + }).onfinish = () => { + getRef('main_navbar').classList.add('hidden') + } + getRef('main_header').classList.add('hidden') + } + } + if (pagesData.lastPage !== pageId) { + document.querySelectorAll('.page').forEach(page => page.classList.add('hidden')) + getRef(pageId).classList.remove('hidden') + getRef(pageId).animate([{ opacity: 0 }, { opacity: 1 }], { duration: 300, fill: 'forwards', easing: 'ease' }) + pagesData.lastPage = pageId } - } - if (pagesData.lastPage !== pageId) { - document.querySelectorAll('.page').forEach(page => page.classList.add('hidden')) - getRef(pageId).classList.remove('hidden') - getRef(pageId).animate([{ opacity: 0 }, { opacity: 1 }], { duration: 300, fill: 'forwards', easing: 'ease' }) - pagesData.lastPage = pageId } document.querySelectorAll('sm-input[data-flo-address]').forEach(input => input.customValidation = floCrypto.validateFloID) document.querySelectorAll('sm-input[data-private-key]').forEach(input => input.customValidation = floCrypto.getPubKeyHex) diff --git a/scripts/components.js b/scripts/components.js index 1f1e510..2435669 100644 --- a/scripts/components.js +++ b/scripts/components.js @@ -9,5 +9,5 @@ class Stack { constructor() { this.items = [] } push(t) { this.items.push(t) } p const smSelect = document.createElement("template"); smSelect.innerHTML = '
', customElements.define("sm-select", class extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(smSelect.content.cloneNode(!0)), this.focusIn = this.focusIn.bind(this), this.reset = this.reset.bind(this), this.open = this.open.bind(this), this.collapse = this.collapse.bind(this), this.toggle = this.toggle.bind(this), this.handleOptionsNavigation = this.handleOptionsNavigation.bind(this), this.handleOptionSelection = this.handleOptionSelection.bind(this), this.handleKeydown = this.handleKeydown.bind(this), this.handleClickOutside = this.handleClickOutside.bind(this), this.selectOption = this.selectOption.bind(this), this.debounce = this.debounce.bind(this), this.elementsChanged = this.elementsChanged.bind(this), this.availableOptions = [], this.previousOption, this.isOpen = !1, this.label = "", this.defaultSelected = "", this.isUnderViewport = !1, this.animationOptions = { duration: 300, fill: "forwards", easing: "ease" }, this.optionList = this.shadowRoot.querySelector(".options"), this.selection = this.shadowRoot.querySelector(".selection"), this.selectedOptionText = this.shadowRoot.querySelector(".selected-option-text") } static get observedAttributes() { return ["disabled", "label", "readonly"] } get value() { return this.getAttribute("value") } set value(t) { const e = this.availableOptions.find(e => e.getAttribute("value") === t); e ? (this.setAttribute("value", t), this.selectOption(e)) : console.warn(`There is no option with ${t} as value`) } debounce(t, e) { let n = null; return (...i) => { window.clearTimeout(n), n = window.setTimeout(() => { t.apply(null, i) }, e) } } reset(t = !0) { if (this.availableOptions[0] && this.previousOption !== this.availableOptions[0]) { const e = this.availableOptions.find(t => t.hasAttribute("selected")) || this.availableOptions[0]; this.value = e.getAttribute("value"), t && this.fireEvent() } } selectOption(t) { this.previousOption !== t && (this.querySelectorAll("[selected]").forEach(t => t.removeAttribute("selected")), this.selectedOptionText.textContent = `${this.label}${t.textContent}`, t.setAttribute("selected", ""), this.previousOption = t) } focusIn() { this.selection.focus() } open() { this.availableOptions.forEach(t => t.setAttribute("tabindex", 0)), this.optionList.classList.remove("hidden"), this.isUnderViewport = this.getBoundingClientRect().bottom + this.optionList.getBoundingClientRect().height > window.innerHeight, this.isUnderViewport ? this.setAttribute("isUnder", "") : this.removeAttribute("isUnder"), this.optionList.animate([{ transform: `translateY(${this.isUnderViewport ? "" : "-"}0.5rem)`, opacity: 0 }, { transform: "translateY(0)", opacity: 1 }], this.animationOptions), this.setAttribute("open", ""), this.style.zIndex = 1e3, (this.availableOptions.find(t => t.hasAttribute("selected")) || this.availableOptions[0]).focus(), document.addEventListener("mousedown", this.handleClickOutside), this.isOpen = !0 } collapse() { this.removeAttribute("open"), this.optionList.animate([{ transform: "translateY(0)", opacity: 1 }, { transform: `translateY(${this.isUnderViewport ? "" : "-"}0.5rem)`, opacity: 0 }], this.animationOptions).onfinish = (() => { this.availableOptions.forEach(t => t.removeAttribute("tabindex")), document.removeEventListener("mousedown", this.handleClickOutside), this.optionList.classList.add("hidden"), this.isOpen = !1, this.style.zIndex = "auto" }) } toggle() { this.isOpen || this.hasAttribute("disabled") ? this.collapse() : this.open() } fireEvent() { this.dispatchEvent(new CustomEvent("change", { bubbles: !0, composed: !0, detail: { value: this.value } })) } handleOptionsNavigation(t) { "ArrowUp" === t.key ? (t.preventDefault(), document.activeElement.previousElementSibling ? document.activeElement.previousElementSibling.focus() : this.availableOptions[this.availableOptions.length - 1].focus()) : "ArrowDown" === t.key && (t.preventDefault(), document.activeElement.nextElementSibling ? document.activeElement.nextElementSibling.focus() : this.availableOptions[0].focus()) } handleOptionSelection(t) { this.previousOption !== document.activeElement && (this.value = document.activeElement.getAttribute("value"), this.fireEvent()) } handleClick(t) { t.target === this ? this.toggle() : (this.handleOptionSelection(), this.collapse()) } handleKeydown(t) { t.target === this ? this.isOpen && "ArrowDown" === t.key ? (t.preventDefault(), (this.availableOptions.find(t => t.hasAttribute("selected")) || this.availableOptions[0]).focus(), this.handleOptionSelection(t)) : " " === t.key && (t.preventDefault(), this.toggle()) : (this.handleOptionsNavigation(t), this.handleOptionSelection(t), ["Enter", " ", "Escape", "Tab"].includes(t.key) && (t.preventDefault(), this.collapse(), this.focusIn())) } handleClickOutside(t) { this.isOpen && !this.contains(t.target) && this.collapse() } elementsChanged() { this.availableOptions = [...this.querySelectorAll("sm-option")], this.reset(!1), this.defaultSelected = this.value } connectedCallback() { this.setAttribute("role", "listbox"), this.hasAttribute("disabled") || this.hasAttribute("readonly") || (this.selection.setAttribute("tabindex", "0"), this.addEventListener("click", this.handleClick), this.addEventListener("keydown", this.handleKeydown)); const t = this.debounce(this.elementsChanged, 100); this.shadowRoot.querySelector("slot").addEventListener("slotchange", t), this.mutationObserver = new MutationObserver(e => { let n = !1; if (e.forEach(e => { switch (e.type) { case "childList": t(); break; case "attributes": n = !0 } }), n) { const t = this.availableOptions.find(t => t.hasAttribute("selected")) || this.availableOptions[0]; this.selectedOptionText.textContent = `${this.label}${t.textContent}`, this.setAttribute("value", t.getAttribute("value")) } }), this.mutationObserver.observe(this, { subtree: !0, childList: !0, attributeFilter: ["selected"] }), new IntersectionObserver((t, e) => { t.forEach(t => { if (t.isIntersecting) { const t = this.selection.getBoundingClientRect().left; t < window.innerWidth / 2 ? this.setAttribute("align-select", "left") : this.setAttribute("align-select", "right") } }) }).observe(this) } disconnectedCallback() { this.removeEventListener("click", this.handleClick), this.removeEventListener("keydown", this.handleKeydown) } attributeChangedCallback(t) { "disabled" === t || "readonly" === t ? this.hasAttribute("disabled") || this.hasAttribute("readonly") ? (this.selection.removeAttribute("tabindex"), this.removeEventListener("click", this.handleClick), this.removeEventListener("keydown", this.handleKeydown)) : (this.selection.setAttribute("tabindex", "0"), this.addEventListener("click", this.handleClick), this.addEventListener("keydown", this.handleKeydown)) : "label" === t && (this.label = this.hasAttribute("label") ? `${this.getAttribute("label")} ` : "") } }); const smOption = document.createElement("template"); smOption.innerHTML = '
', customElements.define("sm-option", class extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(smOption.content.cloneNode(!0)) } connectedCallback() { this.setAttribute("role", "option") } }); const spinner = document.createElement("template"); spinner.innerHTML = ''; class SpinnerLoader extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(spinner.content.cloneNode(!0)) } } window.customElements.define("sm-spinner", SpinnerLoader); const smTextarea = document.createElement("template"); smTextarea.innerHTML = ' ', customElements.define("sm-textarea", class extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(smTextarea.content.cloneNode(!0)), this.textarea = this.shadowRoot.querySelector("textarea"), this.textareaBox = this.shadowRoot.querySelector(".textarea"), this.placeholder = this.shadowRoot.querySelector(".placeholder"), this.reflectedAttributes = ["disabled", "required", "readonly", "rows", "minlength", "maxlength"], this.reset = this.reset.bind(this), this.focusIn = this.focusIn.bind(this), this.fireEvent = this.fireEvent.bind(this), this.checkInput = this.checkInput.bind(this) } static get observedAttributes() { return ["disabled", "value", "placeholder", "required", "readonly", "rows", "minlength", "maxlength"] } get value() { return this.textarea.value } set value(e) { this.setAttribute("value", e), this.fireEvent() } get disabled() { return this.hasAttribute("disabled") } set disabled(e) { e ? this.setAttribute("disabled", "") : this.removeAttribute("disabled") } get isValid() { return this.textarea.checkValidity() } reset() { this.setAttribute("value", "") } focusIn() { this.textarea.focus() } fireEvent() { let e = new Event("input", { bubbles: !0, cancelable: !0, composed: !0 }); this.dispatchEvent(e) } checkInput() { this.hasAttribute("placeholder") && "" !== this.getAttribute("placeholder") && ("" !== this.textarea.value ? this.placeholder.classList.add("hide") : this.placeholder.classList.remove("hide")) } connectedCallback() { this.textarea.addEventListener("input", e => { this.textareaBox.dataset.value = this.textarea.value, this.checkInput() }) } attributeChangedCallback(e, t, n) { this.reflectedAttributes.includes(e) ? this.hasAttribute(e) ? this.textarea.setAttribute(e, this.getAttribute(e) ? this.getAttribute(e) : "") : this.textContent.removeAttribute(e) : "placeholder" === e ? this.placeholder.textContent = this.getAttribute("placeholder") : "value" === e && (this.textarea.value = n, this.textareaBox.dataset.value = n, this.checkInput()) } }); -const themeToggle = document.createElement("template"); themeToggle.innerHTML = ' '; class ThemeToggle extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(themeToggle.content.cloneNode(!0)), this.isChecked = !1, this.hasTheme = "light", this.toggleState = this.toggleState.bind(this), this.fireEvent = this.fireEvent.bind(this), this.handleThemeChange = this.handleThemeChange.bind(this) } static get observedAttributes() { return ["checked"] } daylight() { this.hasTheme = "light", document.body.dataset.theme = "light", this.setAttribute("aria-checked", "false") } nightlight() { this.hasTheme = "dark", document.body.dataset.theme = "dark", this.setAttribute("aria-checked", "true") } toggleState() { this.toggleAttribute("checked"), this.fireEvent() } handleKeyDown(e) { " " === e.key && this.toggleState() } handleThemeChange(e) { e.detail.theme !== this.hasTheme && ("dark" === e.detail.theme ? this.setAttribute("checked", "") : this.removeAttribute("checked")) } fireEvent() { this.dispatchEvent(new CustomEvent("themechange", { bubbles: !0, composed: !0, detail: { theme: this.hasTheme } })) } connectedCallback() { this.setAttribute("role", "switch"), this.setAttribute("aria-label", "theme toggle"), "dark" === localStorage.getItem(`${window.location.hostname}-theme`) ? (this.nightlight(), this.setAttribute("checked", "")) : "light" === localStorage.getItem(`${window.location.hostname}-theme`) ? (this.daylight(), this.removeAttribute("checked")) : window.matchMedia("(prefers-color-scheme: dark)").matches ? (this.nightlight(), this.setAttribute("checked", "")) : (this.daylight(), this.removeAttribute("checked")), this.addEventListener("click", this.toggleState), this.addEventListener("keydown", this.handleKeyDown), document.addEventListener("themechange", this.handleThemeChange) } disconnectedCallback() { this.removeEventListener("click", this.toggleState), this.removeEventListener("keydown", this.handleKeyDown), document.removeEventListener("themechange", this.handleThemeChange) } attributeChangedCallback(e, t, n) { "checked" === e && (this.hasAttribute("checked") ? (this.nightlight(), localStorage.setItem(`${window.location.hostname}-theme`, "dark")) : (this.daylight(), localStorage.setItem(`${window.location.hostname}-theme`, "light"))) } } window.customElements.define("theme-toggle", ThemeToggle); +const themeToggle = document.createElement("template"); themeToggle.innerHTML = ' '; class ThemeToggle extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(themeToggle.content.cloneNode(!0)), this.isChecked = !1, this.hasTheme = "light", this.toggleState = this.toggleState.bind(this), this.fireEvent = this.fireEvent.bind(this), this.handleThemeChange = this.handleThemeChange.bind(this) } static get observedAttributes() { return ["checked"] } daylight() { this.hasTheme = "light", document.body.dataset.theme = "light", this.setAttribute("aria-checked", "false") } nightlight() { this.hasTheme = "dark", document.body.dataset.theme = "dark", this.setAttribute("aria-checked", "true") } toggleState() { if (!document.startViewTransition) return this.toggleAttribute("checked"), void this.fireEvent(); document.startViewTransition(() => { this.toggleAttribute("checked"), this.fireEvent() }) } handleKeyDown(e) { " " === e.key && this.toggleState() } handleThemeChange(e) { e.detail.theme !== this.hasTheme && ("dark" === e.detail.theme ? this.setAttribute("checked", "") : this.removeAttribute("checked")) } fireEvent() { this.dispatchEvent(new CustomEvent("themechange", { bubbles: !0, composed: !0, detail: { theme: this.hasTheme } })) } connectedCallback() { this.setAttribute("role", "switch"), this.setAttribute("aria-label", "theme toggle"), "dark" === localStorage.getItem(`${window.location.hostname}-theme`) ? (this.nightlight(), this.setAttribute("checked", "")) : "light" === localStorage.getItem(`${window.location.hostname}-theme`) ? (this.daylight(), this.removeAttribute("checked")) : window.matchMedia("(prefers-color-scheme: dark)").matches ? (this.nightlight(), this.setAttribute("checked", "")) : (this.daylight(), this.removeAttribute("checked")), this.addEventListener("click", this.toggleState), this.addEventListener("keydown", this.handleKeyDown), document.addEventListener("themechange", this.handleThemeChange) } disconnectedCallback() { this.removeEventListener("click", this.toggleState), this.removeEventListener("keydown", this.handleKeyDown), document.removeEventListener("themechange", this.handleThemeChange) } attributeChangedCallback(e, t, n) { "checked" === e && (this.hasAttribute("checked") ? (this.nightlight(), localStorage.setItem(`${window.location.hostname}-theme`, "dark")) : (this.daylight(), localStorage.setItem(`${window.location.hostname}-theme`, "light"))) } } window.customElements.define("theme-toggle", ThemeToggle); const colorGrid = document.createElement("template"); colorGrid.innerHTML = '\n\n
\n
', customElements.define("color-grid", class extends HTMLElement { constructor() { super(), this.attachShadow({ mode: "open" }).append(colorGrid.content.cloneNode(!0)), this.colorArray = [], this.container = this.shadowRoot.querySelector(".color-tile-container"), this.handleChange = this.handleChange.bind(this), this.setCheckMark = this.setCheckMark.bind(this) } set colors(e) { this.colorArray = e, this.renderTiles() } set selectedColor(e) { if (this.colorArray.includes(e) && this.container.querySelector(`[data-color="${e}"]`)) { const n = this.container.querySelector(`[data-color="${e}"]`); n && (n.querySelector("input").checked = !0, this.setCheckMark(n)) } } randString(e) { let n = "", t = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; for (let r = 0; r < e; r++)n += t.charAt(Math.floor(Math.random() * t.length)); return n } renderTiles() { this.container.innerHTML = ""; const e = document.createDocumentFragment(), n = this.randString(6); this.colorArray.forEach(t => { const r = document.createElement("label"); r.classList.add("color-tile"), r.setAttribute("data-color", t), t.includes("--") ? r.setAttribute("style", `background-color: var(${t})`) : r.setAttribute("style", `background-color: ${t}`), r.innerHTML = `\n \n `, e.append(r) }), this.container.append(e) } setCheckMark(e) { e.parentNode.querySelectorAll(".checkmark").forEach(e => e.remove()); const n = document.createElement("div"); n.classList.add("checkmark"), n.innerHTML = '\n \n ', e.append(n) } handleChange(e) { const n = e.target.closest(".color-tile"); this.setCheckMark(n); const t = n.dataset.color, r = new CustomEvent("colorselected", { bubbles: !0, composed: !0, detail: { value: t } }); this.dispatchEvent(r) } connectedCallback() { this.container.addEventListener("change", this.handleChange) } disconnectedCallback() { this.container.removeEventListener("change", this.handleChange) } }); \ No newline at end of file