diff --git a/css/main.css b/css/main.css index e2302e9..163d3da 100644 --- a/css/main.css +++ b/css/main.css @@ -286,7 +286,7 @@ sm-option { sm-chips { --gap: 0.3rem; background-color: rgba(var(--text-color), 0.06); - border-radius: 0.5rem; + border-radius: 0.7rem; padding: 0.3rem; } @@ -506,6 +506,9 @@ ol { overflow: hidden; cursor: pointer; -webkit-tap-highlight-color: transparent; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; } .empty-state { @@ -746,7 +749,9 @@ ol { position: sticky; top: 0; z-index: 10; - background-color: rgba(var(--background-color), 1); + background-color: rgba(var(--background-color), 0.7); + -webkit-backdrop-filter: blur(1rem); + backdrop-filter: blur(1rem); } #main_header #main_logo { height: 2.5rem; @@ -768,10 +773,10 @@ ol { grid-template-rows: auto 1fr; height: 100%; } -#landing section { +#landing #relative_tasks { height: 100%; } -#landing section > div:first-of-type { +#landing #relative_tasks > div:first-of-type { display: grid; place-content: center; align-self: center; @@ -783,6 +788,100 @@ ol { font-size: 2rem; } +#category_selection { + text-align: center; + width: min(56rem, 100%); + margin-inline: auto; + grid-template-rows: auto 1fr auto; + padding: 1.5rem 0; + gap: 1.5rem; +} +#category_selection h1 { + line-height: 0.9; + margin-bottom: 1rem; +} +#category_selection p { + max-width: 100%; + margin-bottom: 1rem; +} +#category_selection ul { + display: grid; + align-self: flex-start; + gap: 1rem; + grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr)); +} +#category_selection ul li { + display: flex; + -webkit-animation: popin 0.3s ease-out var(--delay) forwards; + animation: popin 0.3s ease-out var(--delay) forwards; + opacity: 0; + transform: scale(0.9); +} +#category_selection ul li:has(:checked) label { + box-shadow: 0 0 0 0.1rem var(--accent-color); + background-color: transparent; +} +#category_selection ul li:has(:checked) label:hover { + box-shadow: 0 0 0 0.2rem var(--accent-color); + background-color: transparent; +} +#category_selection ul li label { + display: flex; + align-items: center; + justify-content: center; + width: 100%; + height: 100%; + text-align: center; + background-color: rgba(var(--text-color), 0.06); + padding: 1rem; + border-radius: 5rem; + cursor: pointer; + font-weight: 500; + transition: background-color 0.3s, box-shadow 0.3s; + aspect-ratio: 1/1; +} +#category_selection ul li label:hover { + background-color: rgba(var(--text-color), 0.03); + box-shadow: 0 0 0 0.1rem rgba(var(--text-color), 0.3); +} +#category_selection ul li input { + display: none; +} +@-webkit-keyframes popin { + to { + opacity: 1; + transform: none; + } +} +@keyframes popin { + to { + opacity: 1; + transform: none; + } +} +#category_selection button { + justify-self: center; + padding: 1rem 3rem; + border-radius: 5rem; + gap: 0.5rem; +} +#category_selection button span { + transform: translateX(1rem); + transition: transform 0.3s; +} +#category_selection button .icon { + opacity: 0; + transform: translateX(-0.5rem); + transition: opacity 0.3s, transform 0.3s; +} +#category_selection button:hover span { + transform: translateX(0); +} +#category_selection button:hover .icon { + opacity: 1; + transform: translateX(0); +} + .task-card { display: grid; grid-template-columns: 1fr auto; @@ -845,11 +944,22 @@ ol { --background: rgba(var(--text-color), 0.06) ; } +#user_profile_button { + background-color: rgba(var(--text-color), 0.06); + border-radius: 2rem; + font-size: 0.8rem; + padding: 0.6rem 0.8rem; + color: currentColor; +} +#user_profile_button .icon { + fill: currentColor; +} + @media screen and (max-width: 40rem) { - #landing section { + #landing #relative_tasks { align-content: flex-start; } - #landing section > div:first-of-type { + #landing #relative_tasks > div:first-of-type { padding: 3rem 0; } #emblem { @@ -862,6 +972,9 @@ ol { padding: 1rem 0; margin-top: 10vh; } + .hide-on-small { + display: none; + } } @media screen and (min-width: 40rem) { h1 { @@ -895,18 +1008,18 @@ ol { #main_header { padding: 2rem 0; } - #landing section { + #landing #relative_tasks { display: grid; grid-template-columns: 1fr 1.2fr; gap: 8vw; } - #landing section > div:first-of-type { + #landing #relative_tasks > div:first-of-type { align-self: flex-start; position: -webkit-sticky; position: sticky; top: 40vh; } - #landing section > div:first-of-type::after { + #landing #relative_tasks > div:first-of-type::after { content: ""; position: absolute; height: 12rem; @@ -916,7 +1029,7 @@ ol { align-self: center; margin-top: 5rem; } - #landing section > div:first-of-type #emblem { + #landing #relative_tasks > div:first-of-type #emblem { position: absolute; align-self: center; right: -1.45rem; @@ -926,7 +1039,7 @@ ol { stroke-width: 0.1rem; margin-top: 5rem; } - #landing section > div:last-of-type { + #landing #relative_tasks > div:last-of-type { margin-top: 3rem; } #home > section { diff --git a/css/main.min.css b/css/main.min.css index cf81a6b..22081fd 100644 --- a/css/main.min.css +++ b/css/main.min.css @@ -1 +1 @@ -*{padding:0;margin:0;box-sizing:border-box;font-family:"IBM Plex Sans",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #4d77ff;--accent-color-rgb: 77, 119, 255;--text-color: 20, 20, 20;--foreground-color: 255, 255, 255;--background-color: 248, 245, 242;--danger-color: rgb(225, 58, 58);--green: #1cad59;--yellow: rgb(255, 207, 65);scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--background-color), 1);position:relative;display:flex;flex-direction:column;color-scheme:light}body[data-theme=dark]{--accent-color: #a0b6ff;--accent-color-rgb: 160, 182, 255;--text-color: 220, 220, 220;--foreground-color: 27, 28, 29;--background-color: 21, 22, 22;--danger-color: rgb(255, 106, 106);--green: #00e676;--yellow: rgb(255, 213, 5);color-scheme:dark}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}input[type=date]{display:flex;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)}input[type=date]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}.warning{line-height:normal;padding:1rem;background-color:khaki;border-radius:.5rem;font-weight:500;color:rgba(0,0,0,.7)}a{text-decoration:none;color:var(--accent-color)}a:focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}h1{font-size:2.5rem}h2{font-size:1.5rem}h3{font-size:1.2rem}h4{font-size:1rem}h5{font-size:.9rem}h6{font-size:.8rem}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;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:.9rem;font-weight:700;white-space:nowrap;padding:.5rem 1rem;border-radius:.5rem;justify-content:center;flex-shrink:0}button:focus-visible,.button:focus-visible{outline:var(--accent-color) solid medium}button:not(:disabled),.button:not(:disabled){color:var(--accent-color);cursor:pointer}button .icon,.button .icon{fill:var(--accent-color)}.button{display:inline-flex;background-color:rgba(var(--text-color), 0.06);color:rgba(var(--text-color), 1)}.button--primary,.button--danger{color:rgba(var(--background-color), 1) !important}.button--primary .icon,.button--danger .icon{fill:rgba(var(--background-color), 1)}.button--primary{padding:.8rem 1.2rem;background-color:rgba(var(--text-color), 1)}.button--danger{background-color:var(--danger-color)}.button--small{padding:.4rem .5rem}.button--colored{color:var(--accent-color) !important}.button--colored .icon{fill:var(--accent-color)}.button--outlined{border:solid .12rem rgba(var(--text-color), 1);background-color:rgba(0,0,0,0);color:rgba(var(--text-color), 1) !important}.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}button:disabled{opacity:.5}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 summary{display:flex;gap:.3rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;color:var(--accent-color)}details summary .down-arrow{fill:var(--accent-color)}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{width:100%;--border-radius: 0.5rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-button{--padding: 0.8rem}sm-button[variant=primary] .icon{fill:rgba(var(--background-color), 1)}sm-button[disabled] .icon{fill:rgba(var(--text-color), 0.6)}sm-button.danger{--background: var(--danger-color);color:rgba(var(--background-color), 1)}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-select{font-size:.9rem;--padding: 0.6rem 0.3rem 0.6rem 0.6rem}sm-option{font-size:.9rem;--border-radius: 0.3rem}sm-chips{--gap: 0.3rem;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:.3rem}sm-chip{font-size:.9rem;--border-radius: 0.5rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:500}sm-chip[selected]{color:rgba(var(--background-color), 1);--background: var(--accent-color)}sm-notifications{z-index:100000}ul,ol{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.wrap-around{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.full-bleed{grid-column:1/-1}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-column{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-direction-column{flex-direction:column}.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-content-start{align-content:flex-start}.align-items-start{align-items:flex-start}.align-self-start{align-self:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.text-center{text-align:center}.justify-start{justify-items:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.justify-items-center{justify-items:center}.align-self-center{align-self:center}.align-self-end{align-self:end}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.flex-direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.h-100{height:100%}.label{font-size:.9rem;color:rgba(var(--text-color), 0.8);font-weight:500;margin-bottom:.3rem}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.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}.interactive{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 !important}.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)}.margin-right-0-3{margin-right:.3rem}.margin-right-0-5{margin-right:.5rem}.margin-right-auto{margin-right:auto}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-top-1-5{margin-top:1.5rem}.margin-bottom-0-5{margin-bottom:.5rem}.margin-bottom-1{margin-bottom:1rem}.margin-bottom-1-5{margin-bottom:1.5rem}.margin-bottom-2{margin-bottom:2rem}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:1.5rem}#confirmation_popup sm-button,#prompt_popup sm-button{margin:0}#confirmation_popup>.flex:last-of-type,#prompt_popup>.flex:last-of-type{padding:0;margin-top:1rem}#confirmation_popup>.flex:last-of-type sm-button:first-of-type,#prompt_popup>.flex:last-of-type sm-button:first-of-type{margin-right:.6rem;margin-left:auto}#prompt_message{margin-bottom:1.5rem}.popup__header{display:grid;gap:.5rem;width:100%;padding:0 1.5rem;align-items:center;justify-items:flex-start}.popup__header__close{padding:.5rem;margin-left:-0.5rem}#loading{display:grid;grid-template-rows:auto 1fr}#loading section{place-content:center;justify-items:center}#loading h4{margin-top:1.5rem;font-weight:500}#loading sm-spinner{--size: 1.5rem}#sign_in,#sign_up{display:grid;height:100%;grid-template-rows:auto 1fr}#sign_in section,#sign_up section{margin:auto;width:min(26rem,100%)}#sign_in sm-form,#sign_up sm-form{margin:2rem 0}#main_header{padding:1rem max(1rem,4vw)}.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)}.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%}.scrolling-wrapper{overflow-y:auto}#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}#app_body{display:grid;grid-template-columns:1rem [main-margin-start] 1fr [main-margin-end] 1rem;height:100%}#app_body>*{grid-column:main-margin}#main_header{padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:10;background-color:rgba(var(--background-color), 1)}#main_header #main_logo{height:2.5rem;width:2.5rem;padding:.6rem;border-radius:5rem;background-color:rgba(var(--text-color), 0.1)}#main_header .button{text-transform:capitalize}#main_header .button--primary{padding:.6rem 1.8rem;border:solid .12rem rgba(var(--text-color), 1)}#landing{display:grid;grid-template-rows:auto 1fr;height:100%}#landing section{height:100%}#landing section>div:first-of-type{display:grid;place-content:center;align-self:center}#landing h1 span:first-of-type{font-size:1.2rem}#landing h1 span:last-of-type{font-size:2rem}.task-card{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center;grid-template-areas:"task-title task-time" "task-description task-description" "task-requisites task-actions"}.task-card:not(:last-of-type){border-bottom:thin solid rgba(var(--text-color), 0.5);padding-bottom:1.5rem;margin-bottom:1.5rem}.task-card:last-of-type{padding-bottom:3rem}.task-card h4{grid-area:task-title;font-size:1.2rem}.task-card>sl-relative-time{grid-area:task-time;font-size:.8rem;color:rgba(var(--text-color), 0.6);text-align:end}.task-card p{grid-area:task-description;font-size:.9rem;color:rgba(var(--text-color), 0.8)}.task-card ul{grid-area:task-requisites}.task-card ul li{font-size:.9rem;color:rgba(var(--text-color), 0.8);font-weight:500}.task-card ul li:not(:last-of-type)::after{content:"•";margin-left:.3rem}.task-card .button{grid-area:task-actions}#profile__header h1,#profile__header h4{line-height:.7}#profile sm-form{width:min(32rem,100%)}#task_popup sm-chips{background-color:rgba(0,0,0,0);padding:0}#task_popup sm-chips sm-chip{--background: rgba(var(--text-color), 0.06) }@media screen and (max-width: 40rem){#landing section{align-content:flex-start}#landing section>div:first-of-type{padding:3rem 0}#emblem{display:none}.task-card{grid-template-areas:"task-title task-time" "task-description task-description" "task-requisites task-requisites" "task-actions task-actions"}#profile__header{padding:1rem 0;margin-top:10vh}}@media screen and (min-width: 40rem){h1{font-size:4rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.2rem}h5{font-size:1rem}h6{font-size:.9rem}sm-popup{--width: 24rem}.popup__header{grid-column:1/-1;padding:1rem 1.5rem 0 1.5rem}#app_body{grid-template-columns:4vw [main-margin-start] 4vw [inner-margin-start] 1fr [inner-margin-end] 4vw [main-margin-end] 4vw}#main_header{padding:2rem 0}#landing section{display:grid;grid-template-columns:1fr 1.2fr;gap:8vw}#landing section>div:first-of-type{align-self:flex-start;position:-webkit-sticky;position:sticky;top:40vh}#landing section>div:first-of-type::after{content:"";position:absolute;height:12rem;width:.1rem;background-color:rgba(var(--text-color), 1);right:0;align-self:center;margin-top:5rem}#landing section>div:first-of-type #emblem{position:absolute;align-self:center;right:-1.45rem;width:3rem;height:3rem;stroke:rgba(var(--text-color), 1);stroke-width:.1rem;margin-top:5rem}#landing section>div:last-of-type{margin-top:3rem}#home>section{padding:0 8vw}#task_popup{--width: 36rem}#profile section{gap:4rem;justify-content:center;align-items:center}}@media(any-hover: hover){html{scrollbar-color:#888 rgba(0,0,0,0)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:currentColor}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.interactive:not([disabled]){transition:background-color .3s}.interactive:not([disabled]):hover{background-color:rgba(var(--text-color), 0.06)}button:not([disabled]),.button:not([disabled]){transition:background-color .3s,filter .3s}button:not([disabled]):hover,.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:"IBM Plex Sans",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #4d77ff;--accent-color-rgb: 77, 119, 255;--text-color: 20, 20, 20;--foreground-color: 255, 255, 255;--background-color: 248, 245, 242;--danger-color: rgb(225, 58, 58);--green: #1cad59;--yellow: rgb(255, 207, 65);scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--background-color), 1);position:relative;display:flex;flex-direction:column;color-scheme:light}body[data-theme=dark]{--accent-color: #a0b6ff;--accent-color-rgb: 160, 182, 255;--text-color: 220, 220, 220;--foreground-color: 27, 28, 29;--background-color: 21, 22, 22;--danger-color: rgb(255, 106, 106);--green: #00e676;--yellow: rgb(255, 213, 5);color-scheme:dark}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}input[type=date]{display:flex;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)}input[type=date]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}.warning{line-height:normal;padding:1rem;background-color:khaki;border-radius:.5rem;font-weight:500;color:rgba(0,0,0,.7)}a{text-decoration:none;color:var(--accent-color)}a:focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}h1{font-size:2.5rem}h2{font-size:1.5rem}h3{font-size:1.2rem}h4{font-size:1rem}h5{font-size:.9rem}h6{font-size:.8rem}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;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:.9rem;font-weight:700;white-space:nowrap;padding:.5rem 1rem;border-radius:.5rem;justify-content:center;flex-shrink:0}button:focus-visible,.button:focus-visible{outline:var(--accent-color) solid medium}button:not(:disabled),.button:not(:disabled){color:var(--accent-color);cursor:pointer}button .icon,.button .icon{fill:var(--accent-color)}.button{display:inline-flex;background-color:rgba(var(--text-color), 0.06);color:rgba(var(--text-color), 1)}.button--primary,.button--danger{color:rgba(var(--background-color), 1) !important}.button--primary .icon,.button--danger .icon{fill:rgba(var(--background-color), 1)}.button--primary{padding:.8rem 1.2rem;background-color:rgba(var(--text-color), 1)}.button--danger{background-color:var(--danger-color)}.button--small{padding:.4rem .5rem}.button--colored{color:var(--accent-color) !important}.button--colored .icon{fill:var(--accent-color)}.button--outlined{border:solid .12rem rgba(var(--text-color), 1);background-color:rgba(0,0,0,0);color:rgba(var(--text-color), 1) !important}.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}button:disabled{opacity:.5}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 summary{display:flex;gap:.3rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;color:var(--accent-color)}details summary .down-arrow{fill:var(--accent-color)}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{width:100%;--border-radius: 0.5rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-button{--padding: 0.8rem}sm-button[variant=primary] .icon{fill:rgba(var(--background-color), 1)}sm-button[disabled] .icon{fill:rgba(var(--text-color), 0.6)}sm-button.danger{--background: var(--danger-color);color:rgba(var(--background-color), 1)}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-select{font-size:.9rem;--padding: 0.6rem 0.3rem 0.6rem 0.6rem}sm-option{font-size:.9rem;--border-radius: 0.3rem}sm-chips{--gap: 0.3rem;background-color:rgba(var(--text-color), 0.06);border-radius:.7rem;padding:.3rem}sm-chip{font-size:.9rem;--border-radius: 0.5rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:500}sm-chip[selected]{color:rgba(var(--background-color), 1);--background: var(--accent-color)}sm-notifications{z-index:100000}ul,ol{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.wrap-around{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word}.full-bleed{grid-column:1/-1}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-column{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-direction-column{flex-direction:column}.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-content-start{align-content:flex-start}.align-items-start{align-items:flex-start}.align-self-start{align-self:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.text-center{text-align:center}.justify-start{justify-items:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.justify-items-center{justify-items:center}.align-self-center{align-self:center}.align-self-end{align-self:end}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.flex-direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.h-100{height:100%}.label{font-size:.9rem;color:rgba(var(--text-color), 0.8);font-weight:500;margin-bottom:.3rem}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.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}.interactive{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-user-select:none;-moz-user-select:none;user-select:none}.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 !important}.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)}.margin-right-0-3{margin-right:.3rem}.margin-right-0-5{margin-right:.5rem}.margin-right-auto{margin-right:auto}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-top-1-5{margin-top:1.5rem}.margin-bottom-0-5{margin-bottom:.5rem}.margin-bottom-1{margin-bottom:1rem}.margin-bottom-1-5{margin-bottom:1.5rem}.margin-bottom-2{margin-bottom:2rem}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:1.5rem}#confirmation_popup sm-button,#prompt_popup sm-button{margin:0}#confirmation_popup>.flex:last-of-type,#prompt_popup>.flex:last-of-type{padding:0;margin-top:1rem}#confirmation_popup>.flex:last-of-type sm-button:first-of-type,#prompt_popup>.flex:last-of-type sm-button:first-of-type{margin-right:.6rem;margin-left:auto}#prompt_message{margin-bottom:1.5rem}.popup__header{display:grid;gap:.5rem;width:100%;padding:0 1.5rem;align-items:center;justify-items:flex-start}.popup__header__close{padding:.5rem;margin-left:-0.5rem}#loading{display:grid;grid-template-rows:auto 1fr}#loading section{place-content:center;justify-items:center}#loading h4{margin-top:1.5rem;font-weight:500}#loading sm-spinner{--size: 1.5rem}#sign_in,#sign_up{display:grid;height:100%;grid-template-rows:auto 1fr}#sign_in section,#sign_up section{margin:auto;width:min(26rem,100%)}#sign_in sm-form,#sign_up sm-form{margin:2rem 0}#main_header{padding:1rem max(1rem,4vw)}.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)}.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%}.scrolling-wrapper{overflow-y:auto}#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}#app_body{display:grid;grid-template-columns:1rem [main-margin-start] 1fr [main-margin-end] 1rem;height:100%}#app_body>*{grid-column:main-margin}#main_header{padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:10;background-color:rgba(var(--background-color), 0.7);-webkit-backdrop-filter:blur(1rem);backdrop-filter:blur(1rem)}#main_header #main_logo{height:2.5rem;width:2.5rem;padding:.6rem;border-radius:5rem;background-color:rgba(var(--text-color), 0.1)}#main_header .button{text-transform:capitalize}#main_header .button--primary{padding:.6rem 1.8rem;border:solid .12rem rgba(var(--text-color), 1)}#landing{display:grid;grid-template-rows:auto 1fr;height:100%}#landing #relative_tasks{height:100%}#landing #relative_tasks>div:first-of-type{display:grid;place-content:center;align-self:center}#landing h1 span:first-of-type{font-size:1.2rem}#landing h1 span:last-of-type{font-size:2rem}#category_selection{text-align:center;width:min(56rem,100%);margin-inline:auto;grid-template-rows:auto 1fr auto;padding:1.5rem 0;gap:1.5rem}#category_selection h1{line-height:.9;margin-bottom:1rem}#category_selection p{max-width:100%;margin-bottom:1rem}#category_selection ul{display:grid;align-self:flex-start;gap:1rem;grid-template-columns:repeat(auto-fill, minmax(11rem, 1fr))}#category_selection ul li{display:flex;-webkit-animation:popin .3s ease-out var(--delay) forwards;animation:popin .3s ease-out var(--delay) forwards;opacity:0;transform:scale(0.9)}#category_selection ul li:has(:checked) label{box-shadow:0 0 0 .1rem var(--accent-color);background-color:rgba(0,0,0,0)}#category_selection ul li:has(:checked) label:hover{box-shadow:0 0 0 .2rem var(--accent-color);background-color:rgba(0,0,0,0)}#category_selection ul li label{display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-align:center;background-color:rgba(var(--text-color), 0.06);padding:1rem;border-radius:5rem;cursor:pointer;font-weight:500;transition:background-color .3s,box-shadow .3s;aspect-ratio:1/1}#category_selection ul li label:hover{background-color:rgba(var(--text-color), 0.03);box-shadow:0 0 0 .1rem rgba(var(--text-color), 0.3)}#category_selection ul li input{display:none}@-webkit-keyframes popin{to{opacity:1;transform:none}}@keyframes popin{to{opacity:1;transform:none}}#category_selection button{justify-self:center;padding:1rem 3rem;border-radius:5rem;gap:.5rem}#category_selection button span{transform:translateX(1rem);transition:transform .3s}#category_selection button .icon{opacity:0;transform:translateX(-0.5rem);transition:opacity .3s,transform .3s}#category_selection button:hover span{transform:translateX(0)}#category_selection button:hover .icon{opacity:1;transform:translateX(0)}.task-card{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center;grid-template-areas:"task-title task-time" "task-description task-description" "task-requisites task-actions"}.task-card:not(:last-of-type){border-bottom:thin solid rgba(var(--text-color), 0.5);padding-bottom:1.5rem;margin-bottom:1.5rem}.task-card:last-of-type{padding-bottom:3rem}.task-card h4{grid-area:task-title;font-size:1.2rem}.task-card>sl-relative-time{grid-area:task-time;font-size:.8rem;color:rgba(var(--text-color), 0.6);text-align:end}.task-card p{grid-area:task-description;font-size:.9rem;color:rgba(var(--text-color), 0.8)}.task-card ul{grid-area:task-requisites}.task-card ul li{font-size:.9rem;color:rgba(var(--text-color), 0.8);font-weight:500}.task-card ul li:not(:last-of-type)::after{content:"•";margin-left:.3rem}.task-card .button{grid-area:task-actions}#profile__header h1,#profile__header h4{line-height:.7}#profile sm-form{width:min(32rem,100%)}#task_popup sm-chips{background-color:rgba(0,0,0,0);padding:0}#task_popup sm-chips sm-chip{--background: rgba(var(--text-color), 0.06) }#user_profile_button{background-color:rgba(var(--text-color), 0.06);border-radius:2rem;font-size:.8rem;padding:.6rem .8rem;color:currentColor}#user_profile_button .icon{fill:currentColor}@media screen and (max-width: 40rem){#landing #relative_tasks{align-content:flex-start}#landing #relative_tasks>div:first-of-type{padding:3rem 0}#emblem{display:none}.task-card{grid-template-areas:"task-title task-time" "task-description task-description" "task-requisites task-requisites" "task-actions task-actions"}#profile__header{padding:1rem 0;margin-top:10vh}.hide-on-small{display:none}}@media screen and (min-width: 40rem){h1{font-size:4rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.2rem}h5{font-size:1rem}h6{font-size:.9rem}sm-popup{--width: 24rem}.popup__header{grid-column:1/-1;padding:1rem 1.5rem 0 1.5rem}#app_body{grid-template-columns:4vw [main-margin-start] 4vw [inner-margin-start] 1fr [inner-margin-end] 4vw [main-margin-end] 4vw}#main_header{padding:2rem 0}#landing #relative_tasks{display:grid;grid-template-columns:1fr 1.2fr;gap:8vw}#landing #relative_tasks>div:first-of-type{align-self:flex-start;position:-webkit-sticky;position:sticky;top:40vh}#landing #relative_tasks>div:first-of-type::after{content:"";position:absolute;height:12rem;width:.1rem;background-color:rgba(var(--text-color), 1);right:0;align-self:center;margin-top:5rem}#landing #relative_tasks>div:first-of-type #emblem{position:absolute;align-self:center;right:-1.45rem;width:3rem;height:3rem;stroke:rgba(var(--text-color), 1);stroke-width:.1rem;margin-top:5rem}#landing #relative_tasks>div:last-of-type{margin-top:3rem}#home>section{padding:0 8vw}#task_popup{--width: 36rem}#profile section{gap:4rem;justify-content:center;align-items:center}}@media(any-hover: hover){html{scrollbar-color:#888 rgba(0,0,0,0)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:currentColor}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.interactive:not([disabled]){transition:background-color .3s}.interactive:not([disabled]):hover{background-color:rgba(var(--text-color), 0.06)}button:not([disabled]),.button:not([disabled]){transition:background-color .3s,filter .3s}button:not([disabled]):hover,.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 b20139c..d283c0c 100644 --- a/css/main.scss +++ b/css/main.scss @@ -298,7 +298,7 @@ sm-option { sm-chips { --gap: 0.3rem; background-color: rgba(var(--text-color), 0.06); - border-radius: 0.5rem; + border-radius: 0.7rem; padding: 0.3rem; } @@ -522,6 +522,7 @@ ol { overflow: hidden; cursor: pointer; -webkit-tap-highlight-color: transparent; + user-select: none; } .empty-state { @@ -776,7 +777,8 @@ ol { position: sticky; top: 0; z-index: 10; - background-color: rgba(var(--background-color), 1); + background-color: rgba(var(--background-color), 0.7); + backdrop-filter: blur(1rem); #main_logo { height: 2.5rem; @@ -801,7 +803,7 @@ ol { grid-template-rows: auto 1fr; height: 100%; - section { + #relative_tasks { height: 100%; &>div:first-of-type { @@ -824,6 +826,110 @@ ol { } } +#category_selection { + text-align: center; + width: min(56rem, 100%); + margin-inline: auto; + grid-template-rows: auto 1fr auto; + padding: 1.5rem 0; + gap: 1.5rem; + + h1 { + line-height: 0.9; + margin-bottom: 1rem; + } + + p { + max-width: 100%; + margin-bottom: 1rem; + } + + ul { + display: grid; + align-self: flex-start; + gap: 1rem; + grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr)); + + li { + display: flex; + animation: popin 0.3s ease-out var(--delay) forwards; + opacity: 0; + transform: scale(0.9); + + &:has(:checked) label { + box-shadow: 0 0 0 0.1rem var(--accent-color); + background-color: transparent; + + &:hover { + box-shadow: 0 0 0 0.2rem var(--accent-color); + background-color: transparent; + } + } + + label { + display: flex; + align-items: center; + justify-content: center; + width: 100%; + height: 100%; + text-align: center; + background-color: rgba(var(--text-color), 0.06); + padding: 1rem; + border-radius: 5rem; + cursor: pointer; + font-weight: 500; + transition: background-color 0.3s, box-shadow 0.3s; + aspect-ratio: 1/1; + + &:hover { + background-color: rgba(var(--text-color), 0.03); + box-shadow: 0 0 0 0.1rem rgba(var(--text-color), 0.3); + } + } + + input { + display: none; + } + } + } + + @keyframes popin { + to { + opacity: 1; + transform: none; + } + } + + button { + justify-self: center; + padding: 1rem 3rem; + border-radius: 5rem; + gap: 0.5rem; + + span { + transform: translateX(1rem); + transition: transform 0.3s; + } + + .icon { + opacity: 0; + transform: translateX(-0.5rem); + transition: opacity 0.3s, transform 0.3s; + } + + &:hover { + span { + transform: translateX(0); + } + + .icon { + opacity: 1; + transform: translateX(0); + } + } + } +} + .task-card { display: grid; grid-template-columns: 1fr auto; @@ -906,9 +1012,21 @@ ol { } } +#user_profile_button { + background-color: rgba(var(--text-color), 0.06); + border-radius: 2rem; + font-size: 0.8rem; + padding: 0.6rem 0.8rem; + color: currentColor; + + .icon { + fill: currentColor; + } +} + @media screen and (max-width: 40rem) { #landing { - section { + #relative_tasks { align-content: flex-start; &>div:first-of-type { @@ -931,6 +1049,10 @@ ol { margin-top: 10vh; } } + + .hide-on-small { + display: none; + } } @media screen and (min-width: 40rem) { @@ -977,7 +1099,7 @@ ol { #landing { - section { + #relative_tasks { display: grid; grid-template-columns: 1fr 1.2fr; gap: 8vw; diff --git a/index.html b/index.html index eaec27a..896a1ee 100644 --- a/index.html +++ b/index.html @@ -76,14 +76,14 @@ adminID: "FKAEdnPfjXLHSYwrXQu377ugN4tXU7VGdf", application: "TEST_MODE", taskCategories: { - c00: 'Creative Writing', - c01: 'Marketing', - c02: 'Design', - c03: 'Development', - c04: 'Social Media Management', - c05: 'Video Making', - c06: 'Project Scouting & Capital Raising', - c07: 'Investment & Finance', + jwrgfk: 'Creative Writing', + u33rsr: 'Marketing', + n2b2a4: 'Design', + h5ml0g: 'Development', + mnmxqm: 'Social Media Management', + sgs6bv: 'Video Making', + utpdbp: 'Project Scouting & Capital Raising', + hohq2a: 'Investment & Finance', } } diff --git a/scripts/app.js b/scripts/app.js index 83fc3dd..7f0f083 100644 --- a/scripts/app.js +++ b/scripts/app.js @@ -716,7 +716,6 @@ async function deleteTask(id) { danger: true }) if (!confirmation) return; - console const taskIndex = floGlobals.appObjects.rmInterns.tasks.findIndex(task => task.id === id); if (taskIndex < 0) return notify('Task not found', 'error'); // in case of error, add the task back to the list @@ -806,11 +805,22 @@ const header = () => { const isUserLoggedIn = page === 'loading' || floGlobals.isUserLoggedIn; return html`
- + + ${!['landing', 'loading'].includes(page) ? html` +
+ RanchiMall + Selects +
+ ` : ''}
- ${isUserLoggedIn ? html`` : html` + ${isUserLoggedIn ? page !== 'loading' ? html` + + `: '' : html`
${page !== 'sign_up' ? html`Get Started` : ''} ${page !== 'sign_in' ? html`Sign in` : ''} @@ -826,42 +836,92 @@ router.addRoute('loading', (state) => {
-

Loading RanchiMall Internships

+

Loading RanchiMall Selects

`); }) -router.addRoute('landing', (state) => { - const { page } = state; - renderElem(getRef('app_body'), html` -
- ${header()} -
-
-

- - Internships - - - @ RanchiMall - -

- -
-
-

Available

-
    - -
-
-
-
- `) - render.availableTasks() +router.addRoute('landing', async (state) => { + try { + const { page } = state; + const interestedCategories = localStorage.getItem('interestedCategories') || '[]'; + floGlobals.interestedCategories = new Set(JSON.parse(interestedCategories)); + if (floGlobals.interestedCategories.size) { + await Promise.all( + Object.keys(floGlobals.taskCategories).map(category => floCloudAPI.requestObjectData(category)) + ) + } + renderElem(getRef('app_body'), html` +
+ ${header()} + ${floGlobals.interestedCategories.size === 0 ? html` +
+
+

+ Welcome to
RanchiMall Selects +

+

+ Select the categories you are interested in
and we will show you the tasks available in those categories +

+
+
    + ${Object.keys(floGlobals.taskCategories).map((category, index) => html` +
  • + toggleCategory(e, category)}> + +
  • + `)} +
+ +
+ ` : html` +
+
+

+ + Internship + + + @ RanchiMall + +

+ +
+
+

Available

+
    + +
+
+
+ `} +
+ `) + if (floGlobals.interestedCategories.size > 0) + render.availableTasks() + } catch (err) { + notify(err, 'error') + } }) +function toggleCategory(e, category) { + if (e.target.checked) { + floGlobals.interestedCategories.add(category) + } else { + floGlobals.interestedCategories.delete(category) + } +} + +function saveCategories() { + localStorage.setItem('interestedCategories', JSON.stringify([...floGlobals.interestedCategories])); + router.routeTo('landing'); +} + function handleSignIn() { privKeyResolver(getRef('private_key_field').value.trim()); router.routeTo('loading'); @@ -941,6 +1001,10 @@ router.addRoute('', renderHome) router.addRoute('home', renderHome) function renderHome(state) { + if (!floGlobals.isUserLoggedIn) { + router.routeTo('landing'); + return; + } if (floGlobals.isAdmin) { } else if (floGlobals.isSubAdmin) { @@ -978,8 +1042,8 @@ function renderHome(state) {
${floGlobals.applications?.size > 0 ? html` - ${floGlobals.applications.size} applications - ${floGlobals.appObjects.rmInterns.tasks.length - floGlobals.applications.size} Available + Applied ${floGlobals.applications.size} + Available ${floGlobals.appObjects.rmInterns.tasks.length - floGlobals.applications.size} ` : html`

Available

@@ -1165,15 +1229,20 @@ window.addEventListener("load", () => { }); floDapps.setMidStartup(() => new Promise((resolve, reject) => { - floCloudAPI.requestObjectData('rmInterns').then(() => { - if (['#/landing', '#/sign_in', '#/sign_up'].some(route => window.location.hash.includes(route))) { - router.routeTo(window.location.hash); - } - resolve() - }).catch(err => { - console.error(err) - reject() - }) + Promise.all([ + floCloudAPI.requestObjectData('rmInterns'), + floCloudAPI.requestObjectData('c00'), + floCloudAPI.requestObjectData('c01'), + ]) + .then(() => { + if (['#/landing', '#/sign_in', '#/sign_up'].some(route => window.location.hash.includes(route))) { + router.routeTo(window.location.hash); + } + resolve() + }).catch(err => { + console.error(err) + reject() + }) }) ) floDapps.setCustomPrivKeyInput(getSignedIn) @@ -1185,16 +1254,23 @@ window.addEventListener("load", () => { floGlobals.myBtcID = getBtcAddress(floGlobals.myFloID) floGlobals.isSubAdmin = floGlobals.subAdmins.includes(floGlobals.myFloID) floGlobals.isAdmin = floGlobals.myFloID === floGlobals.adminID + let showingFloID = true + // alternating between floID and btcID every 10 seconds + setInterval(() => { + getRef('user_profile_id').textContent = showingFloID ? floGlobals.myBtcID : floGlobals.myFloID + showingFloID = !showingFloID + }, 10000) try { if (floGlobals.isSubAdmin) { const promises = [] - // initialize intern app data structure - if (!floGlobals.appObjects.rmInterns) { - console.log('rmInterns not found, resetting') - floGlobals.appObjects.rmInterns = { - tasks: [], + for (const category in floGlobals.taskCategories) { + if (!floGlobals.appObjects[category]) { + console.log('resetting', category) + floGlobals.appObjects[category] = { + tasks: [], + } + promises.push(floCloudAPI.resetObjectData(category)) } - promises.push(floCloudAPI.resetObjectData('rmInterns')) } promises.push(floCloudAPI.requestGeneralData('taskApplications')) await Promise.all(promises) @@ -1247,4 +1323,11 @@ window.addEventListener("load", () => { // handle task deadlines // should we allow users to apply for multiple tasks? // Add icons to the task categories -// handle applicants data securely (encrypted) and allow sub-admins to view them \ No newline at end of file +// handle applicants data securely (encrypted) and allow sub-admins to view them + + +// make separate object data for each categories and show only interested tasks +// ability to save data of interns which are promising beyond 7 days +// ability to mark tasks which are delayed +// have unified view for all tasks in subadmin view +// add option to publish certificates from RIBC \ No newline at end of file diff --git a/scripts/app.min.js b/scripts/app.min.js index 1c353e1..79eb330 100644 --- a/scripts/app.min.js +++ b/scripts/app.min.js @@ -1,4 +1,4 @@ -const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(elementId){return document.getElementById(elementId)}uiGlobals.connectionErrorNotification=[],navigator.onLine||uiGlobals.connectionErrorNotification.push(notify("There seems to be a problem connecting to the internet, Please check you internet connection.","error")),window.addEventListener("offline",(()=>{uiGlobals.connectionErrorNotification.push(notify("There seems to be a problem connecting to the internet, Please check you internet connection.","error"))})),window.addEventListener("online",(()=>{uiGlobals.connectionErrorNotification.forEach((notification=>{getRef("notification_drawer").remove(notification)})),notify("We are back online.","success")}));const getConfirmation=(title,options={})=>new Promise((resolve=>{const{message:message="",cancelText:cancelText="Cancel",confirmText:confirmText="OK",danger:danger=!1}=options;getRef("confirm_title").innerText=title,getRef("confirm_message").innerText=message;const cancelButton=getRef("confirmation_popup").querySelector(".cancel-button"),confirmButton=getRef("confirmation_popup").querySelector(".confirm-button");confirmButton.textContent=confirmText,cancelButton.textContent=cancelText,danger?confirmButton.classList.add("button--danger"):confirmButton.classList.remove("button--danger");const{opened:opened,closed:closed}=openPopup("confirmation_popup");confirmButton.onclick=()=>{closePopup({payload:!0})},cancelButton.onclick=()=>{closePopup()},closed.then((payload=>{confirmButton.onclick=null,cancelButton.onclick=null,resolve(!!payload)}))})),debounce=(callback,wait)=>{let timeoutId=null;return(...args)=>{window.clearTimeout(timeoutId),timeoutId=window.setTimeout((()=>{callback.apply(null,args)}),wait)}};function addClass(elements,className){elements.forEach((element=>{document.querySelector(element).classList.add(className)}))}function removeClass(elements,className){elements.forEach((element=>{document.querySelector(element).classList.remove(className)}))}function getAllElements(selector){return Array.from(document.querySelectorAll(selector))}let zIndex=50;function openPopup(popupId,pinned){return void 0===popupStack.peek()&&document.addEventListener("keydown",(e=>{"Escape"===e.key&&closePopup()})),zIndex++,getRef(popupId).setAttribute("style",`z-index: ${zIndex}`),getRef(popupId).show({pinned:pinned})}function closePopup(options={}){void 0!==popupStack.peek()&&popupStack.peek().popup.hide(options)}function notify(message,mode,options={}){let icon;switch(mode){case"success":icon='';break;case"error":icon='',options.pinned=!0}return"error"===mode&&console.error(message),getRef("notification_drawer").push(message,{icon:icon,...options})}function getFormattedTime(timestamp,format){try{String(timestamp).length<13&&(timestamp*=1e3);let[day,month,date,year]=new Date(timestamp).toString().split(" "),minutes=new Date(timestamp).getMinutes(),hours=new Date(timestamp).getHours();(new Date).toString().split(" ");minutes=minutes<10?`0${minutes}`:minutes;let finalHours="";switch(finalHours=hours>12?`${hours-12}:${minutes}`:0===hours?`12:${minutes}`:`${hours}:${minutes}`,finalHours=hours>=12?`${finalHours} PM`:`${finalHours} AM`,format){case"date-only":return`${month} ${date}, ${year}`;case"time-only":return finalHours;default:return`${month} ${date} ${year}, ${finalHours}`}}catch(e){return console.error(e),timestamp}}function detectBrowser(){let tem,ua=navigator.userAgent,M=ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i)||[];return/trident/i.test(M[1])?(tem=/\brv[ :]+(\d+)/g.exec(ua)||[],"IE "+(tem[1]||"")):"Chrome"===M[1]&&(tem=ua.match(/\b(OPR|Edge)\/(\d+)/),null!=tem)?tem.slice(1).join(" ").replace("OPR","Opera"):(M=M[2]?[M[1],M[2]]:[navigator.appName,navigator.appVersion,"-?"],null!=(tem=ua.match(/version\/(\d+)/i))&&M.splice(1,1,tem[1]),M.join(" "))}function createRipple(event,target){const circle=document.createElement("span"),diameter=Math.max(target.clientWidth,target.clientHeight),radius=diameter/2,targetDimensions=target.getBoundingClientRect();circle.style.width=circle.style.height=`${diameter}px`,circle.style.left=event.clientX-(targetDimensions.left+radius)+"px",circle.style.top=event.clientY-(targetDimensions.top+radius)+"px",circle.classList.add("ripple");const rippleAnimation=circle.animate([{opacity:1,transform:"scale(0)"},{transform:"scale(4)",opacity:0}],{duration:600,fill:"forwards",easing:"ease-out"});target.append(circle),rippleAnimation.onfinish=()=>{circle.remove()}}document.addEventListener("popupopened",(async e=>{history.pushState({type:"popup"},null,null),e.target.id})),document.addEventListener("popupclosed",(e=>{if(zIndex--,"task_popup"===e.target.id)delete getRef("task_popup").dataset.taskId;void 0===popupStack.peek()&&document.removeEventListener("keydown",(e=>{"Escape"===e.key&&closePopup()}))})),window.addEventListener("popstate",(e=>{if(e.state&&"popup"===e.state.type)closePopup()}));class Router{constructor(options={}){const{routes:routes={},state:state={},routingStart:routingStart,routingEnd:routingEnd}=options;this.routes=routes,this.state=state,this.routingStart=routingStart,this.routingEnd=routingEnd,this.lastPage=null,window.addEventListener("hashchange",(e=>this.routeTo(window.location.hash)))}addRoute(route,callback){this.routes[route]=callback}handleRouting=async page=>{this.routingStart&&this.routingStart(this.state),this.routes[page]?(await this.routes[page](this.state),this.lastPage=page):this.routes[404]?this.routes[404](this.state):console.error(`No route found for '${page}' and no '404' route is defined.`),this.routingEnd&&this.routingEnd(this.state)};async routeTo(destination){try{let page,wildcards=[],params={},[path,queryString]=destination.split("?");path.includes("#")&&(path=path.split("#")[1]),path.includes("/")?[,page,...wildcards]=path.split("/"):page=path,this.state={page:page,wildcards:wildcards,lastPage:this.lastPage,params:params},queryString&&(params=new URLSearchParams(queryString),this.state.params=Object.fromEntries(params)),document.startViewTransition?document.startViewTransition((async()=>{await this.handleRouting(page)})):await this.handleRouting(page)}catch(e){console.error(e)}}}class LazyLoader{constructor(container,elementsToRender,renderFn,options={}){const{batchSize:batchSize=10,freshRender:freshRender,bottomFirst:bottomFirst=!1,domUpdated:domUpdated}=options;this.elementsToRender=elementsToRender,this.arrayOfElements="function"==typeof elementsToRender?this.elementsToRender():elementsToRender||[],this.renderFn=renderFn,this.intersectionObserver,this.batchSize=batchSize,this.freshRender=freshRender,this.domUpdated=domUpdated,this.bottomFirst=bottomFirst,this.shouldLazyLoad=!1,this.lastScrollTop=0,this.lastScrollHeight=0,this.lazyContainer=document.querySelector(container),this.update=this.update.bind(this),this.render=this.render.bind(this),this.init=this.init.bind(this),this.clear=this.clear.bind(this)}get elements(){return this.arrayOfElements}init(){this.intersectionObserver=new IntersectionObserver(((entries,observer)=>{entries.forEach((entry=>{entry.isIntersecting&&(observer.disconnect(),this.render({lazyLoad:!0}))}))})),this.mutationObserver=new MutationObserver((mutationList=>{mutationList.forEach((mutation=>{"childList"===mutation.type&&mutation.addedNodes.length&&(this.bottomFirst?this.lazyContainer.firstElementChild&&this.intersectionObserver.observe(this.lazyContainer.firstElementChild):this.lazyContainer.lastElementChild&&this.intersectionObserver.observe(this.lazyContainer.lastElementChild))}))})),this.mutationObserver.observe(this.lazyContainer,{childList:!0}),this.render()}update(elementsToRender){this.arrayOfElements="function"==typeof elementsToRender?this.elementsToRender():elementsToRender||[]}render(options={}){let{lazyLoad:lazyLoad=!1}=options;this.shouldLazyLoad=lazyLoad;const frag=document.createDocumentFragment();lazyLoad?this.bottomFirst?(this.updateEndIndex=this.updateStartIndex,this.updateStartIndex=this.updateEndIndex-this.batchSize):(this.updateStartIndex=this.updateEndIndex,this.updateEndIndex=this.updateEndIndex+this.batchSize):(this.intersectionObserver.disconnect(),this.bottomFirst?(this.updateEndIndex=this.arrayOfElements.length,this.updateStartIndex=this.updateEndIndex-this.batchSize-1):(this.updateStartIndex=0,this.updateEndIndex=this.batchSize),this.lazyContainer.innerHTML=""),this.lastScrollHeight=this.lazyContainer.scrollHeight,this.lastScrollTop=this.lazyContainer.scrollTop,this.arrayOfElements.slice(this.updateStartIndex,this.updateEndIndex).forEach(((element,index)=>{frag.append(this.renderFn(element))})),this.bottomFirst?(this.lazyContainer.prepend(frag),this.lastScrollTop+=this.lazyContainer.scrollHeight-this.lastScrollHeight,this.lazyContainer.scrollTo({top:this.lastScrollTop}),this.lastScrollHeight=this.lazyContainer.scrollHeight):this.lazyContainer.append(frag),!lazyLoad&&this.bottomFirst&&(this.lazyContainer.scrollTop=this.lazyContainer.scrollHeight),!lazyLoad&&this.freshRender&&this.freshRender()}clear(){this.intersectionObserver.disconnect(),this.mutationObserver.disconnect(),this.lazyContainer.innerHTML=""}reset(){this.arrayOfElements="function"==typeof this.elementsToRender?this.elementsToRender():this.elementsToRender||[],this.render()}}function buttonLoader(id,show){const button="string"==typeof id?document.getElementById(id):id;if(!button)return;button.dataset.hasOwnProperty("wasDisabled")||(button.dataset.wasDisabled=button.disabled);const animOptions={duration:200,fill:"forwards",easing:"ease"};if(show)button.disabled=!0,button.parentNode.append(document.createElement("sm-spinner")),button.animate([{clipPath:"circle(100%)"},{clipPath:"circle(0)"}],animOptions);else{button.disabled="true"===button.dataset.wasDisabled,button.animate([{clipPath:"circle(0)"},{clipPath:"circle(100%)"}],animOptions).onfinish=e=>{button.removeAttribute("data-original-state")};const potentialTarget=button.parentNode.querySelector("sm-spinner");potentialTarget&&potentialTarget.remove()}}let isMobileView=!1;const mobileQuery=window.matchMedia("(max-width: 40rem)");function handleMobileChange(e){isMobileView=e.matches}mobileQuery.addEventListener("change",handleMobileChange),handleMobileChange(mobileQuery);const slideInLeft=[{opacity:0,transform:"translateX(1.5rem)"},{opacity:1,transform:"translateX(0)"}],slideOutLeft=[{opacity:1,transform:"translateX(0)"},{opacity:0,transform:"translateX(-1.5rem)"}],slideInRight=[{opacity:0,transform:"translateX(-1.5rem)"},{opacity:1,transform:"translateX(0)"}],slideOutRight=[{opacity:1,transform:"translateX(0)"},{opacity:0,transform:"translateX(1.5rem)"}],slideInDown=[{opacity:0,transform:"translateY(-1.5rem)"},{opacity:1,transform:"translateY(0)"}],slideOutUp=[{opacity:1,transform:"translateY(0)"},{opacity:0,transform:"translateY(-1.5rem)"}];async function saveProfile(){const name=getRef("profile__name").value.trim(),email=getRef("profile__email").value.trim(),college=getRef("profile__college").value.trim(),course=getRef("profile__course").value.trim(),whatsappNumber=getRef("profile__whatsapp_number").value.trim(),stringifiedData=JSON.stringify({name:name,email:email,college:college,course:course,whatsappNumber:whatsappNumber});if(stringifiedData===floDapps.user.decipher(floGlobals.userProfile))return notify("No changes detected","error");if(!await getConfirmation("Save details",{message:"Are you sure you want to save these details?",confirmText:"Save"}))return;const encryptedData=floDapps.user.encipher(stringifiedData);buttonLoader("profile__save",!0),floCloudAPI.sendGeneralData({encryptedData:encryptedData},"userProfile").then((response=>{notify("Profile saved successfully","success"),floGlobals.userProfile=encryptedData})).catch((e=>{notify("An error occurred while saving the profile","error"),console.error(e)})).finally((()=>{buttonLoader("profile__save",!1)}))}async function applyToTask(id){if(!floGlobals.isUserLoggedIn)return location.hash="#/sign_in",notify("You need to be logged in to apply to a task");await getConfirmation("Apply to task",{message:"Are you sure you want to apply to this task?"})&&floCloudAPI.sendGeneralData({taskID:id},"taskApplications").then((response=>{notify("You have successfully applied to the task","success"),floGlobals.applications.add(id),render.availableTasks()})).catch((e=>{notify("An error occurred while applying to the task","error")}))}function editTask(id){const task=floGlobals.appObjects.rmInterns.tasks.find((task=>task.id===id));if(!task)return notify("Task not found","error");const{title:title,description:description,category:category,deadline:deadline}=task;getRef("task_popup__title_input").value=title,getRef("task_popup__description").value=description,getRef("task_popup__category").value=category,getRef("task_popup__deadline").value=deadline,getRef("task_popup").dataset.taskId=id,openPopup("task_popup")}async function saveTask(){if(!await getConfirmation("Save task",{message:"Are you sure you want to save this task?",confirmText:"Save"}))return;const id=getRef("task_popup").dataset.taskId||Math.random().toString(36).substr(2,9),title=getRef("task_popup__title_input").value,description=getRef("task_popup__description").value,category=getRef("task_popup__category").value,deadline=getRef("task_popup__deadline").value,task={id:id,title:title,description:description,category:category,deadline:deadline,status:"open"},foundTask=floGlobals.appObjects.rmInterns.tasks.find((task=>task.id===id));if(foundTask){let taskDetailsChanged=!1;for(const key in task)task[key]!==foundTask[key]&&(taskDetailsChanged=!0,foundTask[key]=task[key]);if(!taskDetailsChanged)return notify("Please update at least one detail to save the changes","error")}else task.date=Date.now(),floGlobals.appObjects.rmInterns.tasks.unshift(task);buttonLoader("task_popup__submit",!0),floCloudAPI.updateObjectData("rmInterns").then((response=>{notify("Task saved successfully","success"),render.availableTasks()})).catch((e=>{notify("An error occurred while saving the task","error"),console.error(e)})).finally((()=>{buttonLoader("task_popup__submit",!1),closePopup()}))}async function deleteTask(id){if(!await getConfirmation("Delete task",{message:"Are you sure you want to delete this task?",confirmText:"Delete",danger:!0}))return;console;const taskIndex=floGlobals.appObjects.rmInterns.tasks.findIndex((task=>task.id===id));if(taskIndex<0)return notify("Task not found","error");const[cloneOfTaskToBeDeleted]=floGlobals.appObjects.rmInterns.tasks.splice(taskIndex,1);floCloudAPI.updateObjectData("rmInterns").then((response=>{notify("Task deleted successfully","success")})).catch((e=>{notify("An error occurred while deleting the task","error"),floGlobals.appObjects.rmInterns.tasks.splice(taskIndex,0,cloneOfTaskToBeDeleted)})).finally((()=>{closePopup(),render.availableTasks()}))}window.smCompConfig={"sm-input":[{selector:"[data-flo-address]",customValidation:value=>value?{isValid:floCrypto.validateFloID(value),errorText:'Invalid FLO address.
It usually starts with "F"'}:{isValid:!1,errorText:"Please enter a FLO address"}},{selector:"[data-btc-address]",customValidation:value=>value?{isValid:btcOperator.validateAddress(value),errorText:'Invalid address.
It usually starts with "1", "3" or "bc1"'}:{isValid:!1,errorText:"Please enter a BTC address"}},{selector:"[data-private-key]",customValidation:(value,inputElem)=>{if(!value)return{isValid:!1,errorText:"Please enter a private key"};if(floCrypto.getPubKeyHex(value)){const forAddress=inputElem.dataset.forAddress;return forAddress?{isValid:btcOperator.verifyKey(forAddress,value),errorText:`This private key does not match the address ${forAddress}`}:{isValid:!0}}return{isValid:!1,errorText:"Invalid private key. Please check and try again."}}},{selector:'[type="email"]',customValidation:(value,target)=>""===value?{isValid:!1,errorText:"Please enter an email address"}:{isValid:/\S+@\S+\.\S+/.test(value),errorText:"Invalid email address"}},{selector:"#profile__whatsapp_number",customValidation:(value,target)=>value.length<10?{isValid:!1,errorText:"Number must be at least 10 digits long"}:value.length>13?{isValid:!1,errorText:"Number must be at most 13 digits long"}:{isValid:!0}}]};const render={task(details={}){const{title:title,description:description,date:date,id:id,status:status,deadline:deadline,category:category}=details;let actions="";if(floGlobals.isUserLoggedIn){if(floGlobals.isSubAdmin)actions=html` +const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(elementId){return document.getElementById(elementId)}uiGlobals.connectionErrorNotification=[],navigator.onLine||uiGlobals.connectionErrorNotification.push(notify("There seems to be a problem connecting to the internet, Please check you internet connection.","error")),window.addEventListener("offline",(()=>{uiGlobals.connectionErrorNotification.push(notify("There seems to be a problem connecting to the internet, Please check you internet connection.","error"))})),window.addEventListener("online",(()=>{uiGlobals.connectionErrorNotification.forEach((notification=>{getRef("notification_drawer").remove(notification)})),notify("We are back online.","success")}));const getConfirmation=(title,options={})=>new Promise((resolve=>{const{message:message="",cancelText:cancelText="Cancel",confirmText:confirmText="OK",danger:danger=!1}=options;getRef("confirm_title").innerText=title,getRef("confirm_message").innerText=message;const cancelButton=getRef("confirmation_popup").querySelector(".cancel-button"),confirmButton=getRef("confirmation_popup").querySelector(".confirm-button");confirmButton.textContent=confirmText,cancelButton.textContent=cancelText,danger?confirmButton.classList.add("button--danger"):confirmButton.classList.remove("button--danger");const{opened:opened,closed:closed}=openPopup("confirmation_popup");confirmButton.onclick=()=>{closePopup({payload:!0})},cancelButton.onclick=()=>{closePopup()},closed.then((payload=>{confirmButton.onclick=null,cancelButton.onclick=null,resolve(!!payload)}))})),debounce=(callback,wait)=>{let timeoutId=null;return(...args)=>{window.clearTimeout(timeoutId),timeoutId=window.setTimeout((()=>{callback.apply(null,args)}),wait)}};function addClass(elements,className){elements.forEach((element=>{document.querySelector(element).classList.add(className)}))}function removeClass(elements,className){elements.forEach((element=>{document.querySelector(element).classList.remove(className)}))}function getAllElements(selector){return Array.from(document.querySelectorAll(selector))}let zIndex=50;function openPopup(popupId,pinned){return void 0===popupStack.peek()&&document.addEventListener("keydown",(e=>{"Escape"===e.key&&closePopup()})),zIndex++,getRef(popupId).setAttribute("style",`z-index: ${zIndex}`),getRef(popupId).show({pinned:pinned})}function closePopup(options={}){void 0!==popupStack.peek()&&popupStack.peek().popup.hide(options)}function notify(message,mode,options={}){let icon;switch(mode){case"success":icon='';break;case"error":icon='',options.pinned=!0}return"error"===mode&&console.error(message),getRef("notification_drawer").push(message,{icon:icon,...options})}function getFormattedTime(timestamp,format){try{String(timestamp).length<13&&(timestamp*=1e3);let[day,month,date,year]=new Date(timestamp).toString().split(" "),minutes=new Date(timestamp).getMinutes(),hours=new Date(timestamp).getHours();(new Date).toString().split(" ");minutes=minutes<10?`0${minutes}`:minutes;let finalHours="";switch(finalHours=hours>12?`${hours-12}:${minutes}`:0===hours?`12:${minutes}`:`${hours}:${minutes}`,finalHours=hours>=12?`${finalHours} PM`:`${finalHours} AM`,format){case"date-only":return`${month} ${date}, ${year}`;case"time-only":return finalHours;default:return`${month} ${date} ${year}, ${finalHours}`}}catch(e){return console.error(e),timestamp}}function detectBrowser(){let tem,ua=navigator.userAgent,M=ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i)||[];return/trident/i.test(M[1])?(tem=/\brv[ :]+(\d+)/g.exec(ua)||[],"IE "+(tem[1]||"")):"Chrome"===M[1]&&(tem=ua.match(/\b(OPR|Edge)\/(\d+)/),null!=tem)?tem.slice(1).join(" ").replace("OPR","Opera"):(M=M[2]?[M[1],M[2]]:[navigator.appName,navigator.appVersion,"-?"],null!=(tem=ua.match(/version\/(\d+)/i))&&M.splice(1,1,tem[1]),M.join(" "))}function createRipple(event,target){const circle=document.createElement("span"),diameter=Math.max(target.clientWidth,target.clientHeight),radius=diameter/2,targetDimensions=target.getBoundingClientRect();circle.style.width=circle.style.height=`${diameter}px`,circle.style.left=event.clientX-(targetDimensions.left+radius)+"px",circle.style.top=event.clientY-(targetDimensions.top+radius)+"px",circle.classList.add("ripple");const rippleAnimation=circle.animate([{opacity:1,transform:"scale(0)"},{transform:"scale(4)",opacity:0}],{duration:600,fill:"forwards",easing:"ease-out"});target.append(circle),rippleAnimation.onfinish=()=>{circle.remove()}}document.addEventListener("popupopened",(async e=>{history.pushState({type:"popup"},null,null),e.target.id})),document.addEventListener("popupclosed",(e=>{if(zIndex--,"task_popup"===e.target.id)delete getRef("task_popup").dataset.taskId;void 0===popupStack.peek()&&document.removeEventListener("keydown",(e=>{"Escape"===e.key&&closePopup()}))})),window.addEventListener("popstate",(e=>{if(e.state&&"popup"===e.state.type)closePopup()}));class Router{constructor(options={}){const{routes:routes={},state:state={},routingStart:routingStart,routingEnd:routingEnd}=options;this.routes=routes,this.state=state,this.routingStart=routingStart,this.routingEnd=routingEnd,this.lastPage=null,window.addEventListener("hashchange",(e=>this.routeTo(window.location.hash)))}addRoute(route,callback){this.routes[route]=callback}handleRouting=async page=>{this.routingStart&&this.routingStart(this.state),this.routes[page]?(await this.routes[page](this.state),this.lastPage=page):this.routes[404]?this.routes[404](this.state):console.error(`No route found for '${page}' and no '404' route is defined.`),this.routingEnd&&this.routingEnd(this.state)};async routeTo(destination){try{let page,wildcards=[],params={},[path,queryString]=destination.split("?");path.includes("#")&&(path=path.split("#")[1]),path.includes("/")?[,page,...wildcards]=path.split("/"):page=path,this.state={page:page,wildcards:wildcards,lastPage:this.lastPage,params:params},queryString&&(params=new URLSearchParams(queryString),this.state.params=Object.fromEntries(params)),document.startViewTransition?document.startViewTransition((async()=>{await this.handleRouting(page)})):await this.handleRouting(page)}catch(e){console.error(e)}}}class LazyLoader{constructor(container,elementsToRender,renderFn,options={}){const{batchSize:batchSize=10,freshRender:freshRender,bottomFirst:bottomFirst=!1,domUpdated:domUpdated}=options;this.elementsToRender=elementsToRender,this.arrayOfElements="function"==typeof elementsToRender?this.elementsToRender():elementsToRender||[],this.renderFn=renderFn,this.intersectionObserver,this.batchSize=batchSize,this.freshRender=freshRender,this.domUpdated=domUpdated,this.bottomFirst=bottomFirst,this.shouldLazyLoad=!1,this.lastScrollTop=0,this.lastScrollHeight=0,this.lazyContainer=document.querySelector(container),this.update=this.update.bind(this),this.render=this.render.bind(this),this.init=this.init.bind(this),this.clear=this.clear.bind(this)}get elements(){return this.arrayOfElements}init(){this.intersectionObserver=new IntersectionObserver(((entries,observer)=>{entries.forEach((entry=>{entry.isIntersecting&&(observer.disconnect(),this.render({lazyLoad:!0}))}))})),this.mutationObserver=new MutationObserver((mutationList=>{mutationList.forEach((mutation=>{"childList"===mutation.type&&mutation.addedNodes.length&&(this.bottomFirst?this.lazyContainer.firstElementChild&&this.intersectionObserver.observe(this.lazyContainer.firstElementChild):this.lazyContainer.lastElementChild&&this.intersectionObserver.observe(this.lazyContainer.lastElementChild))}))})),this.mutationObserver.observe(this.lazyContainer,{childList:!0}),this.render()}update(elementsToRender){this.arrayOfElements="function"==typeof elementsToRender?this.elementsToRender():elementsToRender||[]}render(options={}){let{lazyLoad:lazyLoad=!1}=options;this.shouldLazyLoad=lazyLoad;const frag=document.createDocumentFragment();lazyLoad?this.bottomFirst?(this.updateEndIndex=this.updateStartIndex,this.updateStartIndex=this.updateEndIndex-this.batchSize):(this.updateStartIndex=this.updateEndIndex,this.updateEndIndex=this.updateEndIndex+this.batchSize):(this.intersectionObserver.disconnect(),this.bottomFirst?(this.updateEndIndex=this.arrayOfElements.length,this.updateStartIndex=this.updateEndIndex-this.batchSize-1):(this.updateStartIndex=0,this.updateEndIndex=this.batchSize),this.lazyContainer.innerHTML=""),this.lastScrollHeight=this.lazyContainer.scrollHeight,this.lastScrollTop=this.lazyContainer.scrollTop,this.arrayOfElements.slice(this.updateStartIndex,this.updateEndIndex).forEach(((element,index)=>{frag.append(this.renderFn(element))})),this.bottomFirst?(this.lazyContainer.prepend(frag),this.lastScrollTop+=this.lazyContainer.scrollHeight-this.lastScrollHeight,this.lazyContainer.scrollTo({top:this.lastScrollTop}),this.lastScrollHeight=this.lazyContainer.scrollHeight):this.lazyContainer.append(frag),!lazyLoad&&this.bottomFirst&&(this.lazyContainer.scrollTop=this.lazyContainer.scrollHeight),!lazyLoad&&this.freshRender&&this.freshRender()}clear(){this.intersectionObserver.disconnect(),this.mutationObserver.disconnect(),this.lazyContainer.innerHTML=""}reset(){this.arrayOfElements="function"==typeof this.elementsToRender?this.elementsToRender():this.elementsToRender||[],this.render()}}function buttonLoader(id,show){const button="string"==typeof id?document.getElementById(id):id;if(!button)return;button.dataset.hasOwnProperty("wasDisabled")||(button.dataset.wasDisabled=button.disabled);const animOptions={duration:200,fill:"forwards",easing:"ease"};if(show)button.disabled=!0,button.parentNode.append(document.createElement("sm-spinner")),button.animate([{clipPath:"circle(100%)"},{clipPath:"circle(0)"}],animOptions);else{button.disabled="true"===button.dataset.wasDisabled,button.animate([{clipPath:"circle(0)"},{clipPath:"circle(100%)"}],animOptions).onfinish=e=>{button.removeAttribute("data-original-state")};const potentialTarget=button.parentNode.querySelector("sm-spinner");potentialTarget&&potentialTarget.remove()}}let isMobileView=!1;const mobileQuery=window.matchMedia("(max-width: 40rem)");function handleMobileChange(e){isMobileView=e.matches}mobileQuery.addEventListener("change",handleMobileChange),handleMobileChange(mobileQuery);const slideInLeft=[{opacity:0,transform:"translateX(1.5rem)"},{opacity:1,transform:"translateX(0)"}],slideOutLeft=[{opacity:1,transform:"translateX(0)"},{opacity:0,transform:"translateX(-1.5rem)"}],slideInRight=[{opacity:0,transform:"translateX(-1.5rem)"},{opacity:1,transform:"translateX(0)"}],slideOutRight=[{opacity:1,transform:"translateX(0)"},{opacity:0,transform:"translateX(1.5rem)"}],slideInDown=[{opacity:0,transform:"translateY(-1.5rem)"},{opacity:1,transform:"translateY(0)"}],slideOutUp=[{opacity:1,transform:"translateY(0)"},{opacity:0,transform:"translateY(-1.5rem)"}];async function saveProfile(){const name=getRef("profile__name").value.trim(),email=getRef("profile__email").value.trim(),college=getRef("profile__college").value.trim(),course=getRef("profile__course").value.trim(),whatsappNumber=getRef("profile__whatsapp_number").value.trim(),stringifiedData=JSON.stringify({name:name,email:email,college:college,course:course,whatsappNumber:whatsappNumber});if(stringifiedData===floDapps.user.decipher(floGlobals.userProfile))return notify("No changes detected","error");if(!await getConfirmation("Save details",{message:"Are you sure you want to save these details?",confirmText:"Save"}))return;const encryptedData=floDapps.user.encipher(stringifiedData);buttonLoader("profile__save",!0),floCloudAPI.sendGeneralData({encryptedData:encryptedData},"userProfile").then((response=>{notify("Profile saved successfully","success"),floGlobals.userProfile=encryptedData})).catch((e=>{notify("An error occurred while saving the profile","error"),console.error(e)})).finally((()=>{buttonLoader("profile__save",!1)}))}async function applyToTask(id){if(!floGlobals.isUserLoggedIn)return location.hash="#/sign_in",notify("You need to be logged in to apply to a task");await getConfirmation("Apply to task",{message:"Are you sure you want to apply to this task?"})&&floCloudAPI.sendGeneralData({taskID:id},"taskApplications").then((response=>{notify("You have successfully applied to the task","success"),floGlobals.applications.add(id),render.availableTasks()})).catch((e=>{notify("An error occurred while applying to the task","error")}))}function editTask(id){const task=floGlobals.appObjects.rmInterns.tasks.find((task=>task.id===id));if(!task)return notify("Task not found","error");const{title:title,description:description,category:category,deadline:deadline}=task;getRef("task_popup__title_input").value=title,getRef("task_popup__description").value=description,getRef("task_popup__category").value=category,getRef("task_popup__deadline").value=deadline,getRef("task_popup").dataset.taskId=id,openPopup("task_popup")}async function saveTask(){if(!await getConfirmation("Save task",{message:"Are you sure you want to save this task?",confirmText:"Save"}))return;const id=getRef("task_popup").dataset.taskId||Math.random().toString(36).substr(2,9),title=getRef("task_popup__title_input").value,description=getRef("task_popup__description").value,category=getRef("task_popup__category").value,deadline=getRef("task_popup__deadline").value,task={id:id,title:title,description:description,category:category,deadline:deadline,status:"open"},foundTask=floGlobals.appObjects.rmInterns.tasks.find((task=>task.id===id));if(foundTask){let taskDetailsChanged=!1;for(const key in task)task[key]!==foundTask[key]&&(taskDetailsChanged=!0,foundTask[key]=task[key]);if(!taskDetailsChanged)return notify("Please update at least one detail to save the changes","error")}else task.date=Date.now(),floGlobals.appObjects.rmInterns.tasks.unshift(task);buttonLoader("task_popup__submit",!0),floCloudAPI.updateObjectData("rmInterns").then((response=>{notify("Task saved successfully","success"),render.availableTasks()})).catch((e=>{notify("An error occurred while saving the task","error"),console.error(e)})).finally((()=>{buttonLoader("task_popup__submit",!1),closePopup()}))}async function deleteTask(id){if(!await getConfirmation("Delete task",{message:"Are you sure you want to delete this task?",confirmText:"Delete",danger:!0}))return;const taskIndex=floGlobals.appObjects.rmInterns.tasks.findIndex((task=>task.id===id));if(taskIndex<0)return notify("Task not found","error");const[cloneOfTaskToBeDeleted]=floGlobals.appObjects.rmInterns.tasks.splice(taskIndex,1);floCloudAPI.updateObjectData("rmInterns").then((response=>{notify("Task deleted successfully","success")})).catch((e=>{notify("An error occurred while deleting the task","error"),floGlobals.appObjects.rmInterns.tasks.splice(taskIndex,0,cloneOfTaskToBeDeleted)})).finally((()=>{closePopup(),render.availableTasks()}))}window.smCompConfig={"sm-input":[{selector:"[data-flo-address]",customValidation:value=>value?{isValid:floCrypto.validateFloID(value),errorText:'Invalid FLO address.
It usually starts with "F"'}:{isValid:!1,errorText:"Please enter a FLO address"}},{selector:"[data-btc-address]",customValidation:value=>value?{isValid:btcOperator.validateAddress(value),errorText:'Invalid address.
It usually starts with "1", "3" or "bc1"'}:{isValid:!1,errorText:"Please enter a BTC address"}},{selector:"[data-private-key]",customValidation:(value,inputElem)=>{if(!value)return{isValid:!1,errorText:"Please enter a private key"};if(floCrypto.getPubKeyHex(value)){const forAddress=inputElem.dataset.forAddress;return forAddress?{isValid:btcOperator.verifyKey(forAddress,value),errorText:`This private key does not match the address ${forAddress}`}:{isValid:!0}}return{isValid:!1,errorText:"Invalid private key. Please check and try again."}}},{selector:'[type="email"]',customValidation:(value,target)=>""===value?{isValid:!1,errorText:"Please enter an email address"}:{isValid:/\S+@\S+\.\S+/.test(value),errorText:"Invalid email address"}},{selector:"#profile__whatsapp_number",customValidation:(value,target)=>value.length<10?{isValid:!1,errorText:"Number must be at least 10 digits long"}:value.length>13?{isValid:!1,errorText:"Number must be at most 13 digits long"}:{isValid:!0}}]};const render={task(details={}){const{title:title,description:description,date:date,id:id,status:status,deadline:deadline,category:category}=details;let actions="";if(floGlobals.isUserLoggedIn){if(floGlobals.isSubAdmin)actions=html` ${floGlobals.applications[id]?.size||0} applied @@ -19,18 +19,29 @@ const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(e `},availableTasks(options={}){const{type:type}=options;if(0===(floGlobals.appObjects?.rmInterns.tasks||[]).length)return renderElem(getRef("available_tasks_list"),html`

No tasks available

`);let tasksList=floGlobals.appObjects.rmInterns.tasks;type&&("applications"===type?tasksList=tasksList.filter((task=>floGlobals.applications.has(task.id))):"available"===type&&(tasksList=tasksList.filter((task=>!floGlobals.applications.has(task.id))))),tasksList=tasksList.map(render.task),renderElem(getRef("available_tasks_list"),html`${tasksList}`)}},router=new Router({routingStart(state){"scrollRestoration"in history&&(history.scrollRestoration="manual"),window.scrollTo(0,0)},routingEnd(state){const{page:page,lastPage:lastPage}=state;lastPage!==page&&closePopup()}}),header=()=>{const{page:page}=router.state,isUserLoggedIn="loading"===page||floGlobals.isUserLoggedIn;return html`
- + + ${["landing","loading"].includes(page)?"":html` +
+ RanchiMall + Selects +
+ `}
- ${isUserLoggedIn?html``:html` + ${isUserLoggedIn?"loading"!==page?html` + + `:"":html`
${"sign_up"!==page?html`Get Started`:""} ${"sign_in"!==page?html`Sign in`:""}
`}
- `};function handleSignIn(){privKeyResolver(getRef("private_key_field").value.trim()),router.routeTo("loading")}function handleSignUp(){const privKey=getRef("generated_private_key").value.trim();privKeyResolver(privKey),router.routeTo("loading")}function handleSubAdminViewChange(e){location.hash=`#/home?view=${e.target.value}`}function renderHome(state){if(floGlobals.isAdmin);else if(floGlobals.isSubAdmin){const{}=state;renderElem(getRef("app_body"),html` + `};function toggleCategory(e,category){e.target.checked?floGlobals.interestedCategories.add(category):floGlobals.interestedCategories.delete(category)}function saveCategories(){localStorage.setItem("interestedCategories",JSON.stringify([...floGlobals.interestedCategories])),router.routeTo("landing")}function handleSignIn(){privKeyResolver(getRef("private_key_field").value.trim()),router.routeTo("loading")}function handleSignUp(){const privKey=getRef("generated_private_key").value.trim();privKeyResolver(privKey),router.routeTo("loading")}function handleSubAdminViewChange(e){location.hash=`#/home?view=${e.target.value}`}function renderHome(state){if(floGlobals.isUserLoggedIn)if(floGlobals.isAdmin);else if(floGlobals.isSubAdmin){const{}=state;renderElem(getRef("app_body"),html`
${header()}
@@ -54,8 +65,8 @@ const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(e
${floGlobals.applications?.size>0?html` - ${floGlobals.applications.size} applications - ${floGlobals.appObjects.rmInterns.tasks.length-floGlobals.applications.size} Available + Applied ${floGlobals.applications.size} + Available ${floGlobals.appObjects.rmInterns.tasks.length-floGlobals.applications.size} `:html`

Available

@@ -66,41 +77,66 @@ const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(e
- `),render.availableTasks({type:view}))}}function handleViewChange(e){location.hash=`#/home?view=${e.target.value}`}router.addRoute("loading",(state=>{renderElem(getRef("app_body"),html` + `),render.availableTasks({type:view}))}else router.routeTo("landing")}function handleViewChange(e){location.hash=`#/home?view=${e.target.value}`}router.addRoute("loading",(state=>{renderElem(getRef("app_body"),html`
${header()}
-

Loading RanchiMall Internships

+

Loading RanchiMall Selects

- `)})),router.addRoute("landing",(state=>{const{page:page}=state;renderElem(getRef("app_body"),html` -
- ${header()} -
-
-

- - Internships - - - @ RanchiMall - -

- -
-
-

Available

-
    - -
-
-
-
- `),render.availableTasks()})),router.addRoute("sign_in",(state=>{const{}=state;let dataset={};floGlobals.isPrivKeySecured||(dataset.privateKey=""),renderElem(getRef("app_body"),html` + `)})),router.addRoute("landing",(async state=>{try{const{page:page}=state,interestedCategories=localStorage.getItem("interestedCategories")||"[]";floGlobals.interestedCategories=new Set(JSON.parse(interestedCategories)),floGlobals.interestedCategories.size&&await Promise.all(Object.keys(floGlobals.taskCategories).map((category=>floCloudAPI.requestObjectData(category)))),renderElem(getRef("app_body"),html` +
+ ${header()} + ${0===floGlobals.interestedCategories.size?html` +
+
+

+ Welcome to
RanchiMall Selects +

+

+ Select the categories you are interested in
and we will show you the tasks available in those categories +

+
+
    + ${Object.keys(floGlobals.taskCategories).map(((category,index)=>html` +
  • + toggleCategory(e,category)}> + +
  • + `))} +
+ +
+ `:html` +
+
+

+ + Internship + + + @ RanchiMall + +

+ +
+
+

Available

+
    + +
+
+
+ `} +
+ `),floGlobals.interestedCategories.size>0&&render.availableTasks()}catch(err){notify(err,"error")}})),router.addRoute("sign_in",(state=>{const{}=state;let dataset={};floGlobals.isPrivKeySecured||(dataset.privateKey=""),renderElem(getRef("app_body"),html`
${header()}
@@ -206,4 +242,4 @@ const uiGlobals={},{html:html,svg:svg,render:renderElem}=uhtml;function getRef(e

404

Page not found

- `)}));let privKeyResolver=null;function getSignedIn(passwordType){return new Promise(((resolve,reject)=>{privKeyResolver=resolve;try{getPromptInput("Enter password","",{isPassword:!0}).then((password=>{password&&resolve(password)}))}catch(err){floGlobals.isPrivKeySecured="PIN/Password"===passwordType,["#/landing","#/sign_in","#/sign_up"].some((route=>window.location.hash.includes(route)))||(history.replaceState(null,null,"#/landing"),router.routeTo("#/landing"))}}))}function setSecurePassword(){if(!floGlobals.isPrivKeySecured){const password=getRef("secure_pwd_input").value.trim();floDapps.securePrivKey(password).then((()=>{floGlobals.isPrivKeySecured=!0,notify("Password set successfully","success"),closePopup()})).catch((err=>{notify(err,"error")}))}}function signOut(){getConfirmation("Sign out?",{message:"You are about to sign out of the app, continue?",confirmText:"Leave",cancelText:"Stay"}).then((async res=>{res&&(await floDapps.clearCredentials(),location.reload())}))}const btcAddresses={},floAddresses={};function getBtcAddress(floAddress){return btcAddresses[floAddress]||(btcAddresses[floAddress]=btcOperator.convert.legacy2bech(floAddress)),btcAddresses[floAddress]}function getFloAddress(btcAddress){return floAddresses[btcAddress]||(floAddresses[btcAddress]=floCrypto.toFloID(btcAddress)),floAddresses[btcAddress]}router.routeTo("loading"),window.addEventListener("load",(()=>{const[browserName,browserVersion]=detectBrowser().split(" "),supportedVersions={Chrome:85,Firefox:75,Safari:13};browserName in supportedVersions?parseInt(browserVersion){"Escape"===e.key&&closePopup()})),document.addEventListener("copy",(()=>{notify("copied","success")})),document.addEventListener("pointerdown",(e=>{e.target.closest("button:not(:disabled), .interactive:not(:disabled)")&&createRipple(e,e.target.closest("button, .interactive"))})),floDapps.setMidStartup((()=>new Promise(((resolve,reject)=>{floCloudAPI.requestObjectData("rmInterns").then((()=>{["#/landing","#/sign_in","#/sign_up"].some((route=>window.location.hash.includes(route)))&&router.routeTo(window.location.hash),resolve()})).catch((err=>{console.error(err),reject()}))})))),floDapps.setCustomPrivKeyInput(getSignedIn),floDapps.launchStartUp().then((async result=>{console.log(result),floGlobals.isUserLoggedIn=!0,floGlobals.myFloID=getFloAddress(floDapps.user.id),floGlobals.myBtcID=getBtcAddress(floGlobals.myFloID),floGlobals.isSubAdmin=floGlobals.subAdmins.includes(floGlobals.myFloID),floGlobals.isAdmin=floGlobals.myFloID===floGlobals.adminID;try{if(floGlobals.isSubAdmin){const promises=[];floGlobals.appObjects.rmInterns||(console.log("rmInterns not found, resetting"),floGlobals.appObjects.rmInterns={tasks:[]},promises.push(floCloudAPI.resetObjectData("rmInterns"))),promises.push(floCloudAPI.requestGeneralData("taskApplications")),await Promise.all(promises);const taskApplications=floDapps.getNextGeneralData("taskApplications","0");floGlobals.applications={};for(const application in taskApplications){const{message:{taskID:taskID},senderID:senderID}=taskApplications[application];floGlobals.applications[taskID]||(floGlobals.applications[taskID]=new Set),floGlobals.applications[taskID].add(senderID)}}else if(floGlobals.isAdmin);else{floGlobals.applications=new Set;const promises=[floCloudAPI.requestGeneralData("taskApplications",{senderID:[floGlobals.myFloID,floGlobals.myBtcID]}),floCloudAPI.requestGeneralData("userProfile",{senderID:[floGlobals.myFloID,floGlobals.myBtcID]})];await Promise.all(promises);const taskApplications=floDapps.getNextGeneralData("taskApplications","0");for(const application in taskApplications){const{message:{taskID:taskID}}=taskApplications[application];(floGlobals.appObjects.rmInterns.tasks||[]).some((task=>task.id===taskID))&&floGlobals.applications.add(taskID)}const userProfile=floDapps.getNextGeneralData("userProfile","0");floGlobals.userProfile=Object.values(userProfile).at(-1)?.message.encryptedData}["#/landing","#/sign_in","#/sign_up"].includes(window.location.hash)?(history.replaceState(null,null,"#/home"),router.routeTo("home")):router.routeTo(window.location.hash)}catch(err){console.error(err)}})).catch((error=>console.error(error)))})); \ No newline at end of file + `)}));let privKeyResolver=null;function getSignedIn(passwordType){return new Promise(((resolve,reject)=>{privKeyResolver=resolve;try{getPromptInput("Enter password","",{isPassword:!0}).then((password=>{password&&resolve(password)}))}catch(err){floGlobals.isPrivKeySecured="PIN/Password"===passwordType,["#/landing","#/sign_in","#/sign_up"].some((route=>window.location.hash.includes(route)))||(history.replaceState(null,null,"#/landing"),router.routeTo("#/landing"))}}))}function setSecurePassword(){if(!floGlobals.isPrivKeySecured){const password=getRef("secure_pwd_input").value.trim();floDapps.securePrivKey(password).then((()=>{floGlobals.isPrivKeySecured=!0,notify("Password set successfully","success"),closePopup()})).catch((err=>{notify(err,"error")}))}}function signOut(){getConfirmation("Sign out?",{message:"You are about to sign out of the app, continue?",confirmText:"Leave",cancelText:"Stay"}).then((async res=>{res&&(await floDapps.clearCredentials(),location.reload())}))}const btcAddresses={},floAddresses={};function getBtcAddress(floAddress){return btcAddresses[floAddress]||(btcAddresses[floAddress]=btcOperator.convert.legacy2bech(floAddress)),btcAddresses[floAddress]}function getFloAddress(btcAddress){return floAddresses[btcAddress]||(floAddresses[btcAddress]=floCrypto.toFloID(btcAddress)),floAddresses[btcAddress]}router.routeTo("loading"),window.addEventListener("load",(()=>{const[browserName,browserVersion]=detectBrowser().split(" "),supportedVersions={Chrome:85,Firefox:75,Safari:13};browserName in supportedVersions?parseInt(browserVersion){"Escape"===e.key&&closePopup()})),document.addEventListener("copy",(()=>{notify("copied","success")})),document.addEventListener("pointerdown",(e=>{e.target.closest("button:not(:disabled), .interactive:not(:disabled)")&&createRipple(e,e.target.closest("button, .interactive"))})),floDapps.setMidStartup((()=>new Promise(((resolve,reject)=>{Promise.all([floCloudAPI.requestObjectData("rmInterns"),floCloudAPI.requestObjectData("c00"),floCloudAPI.requestObjectData("c01")]).then((()=>{["#/landing","#/sign_in","#/sign_up"].some((route=>window.location.hash.includes(route)))&&router.routeTo(window.location.hash),resolve()})).catch((err=>{console.error(err),reject()}))})))),floDapps.setCustomPrivKeyInput(getSignedIn),floDapps.launchStartUp().then((async result=>{console.log(result),floGlobals.isUserLoggedIn=!0,floGlobals.myFloID=getFloAddress(floDapps.user.id),floGlobals.myBtcID=getBtcAddress(floGlobals.myFloID),floGlobals.isSubAdmin=floGlobals.subAdmins.includes(floGlobals.myFloID),floGlobals.isAdmin=floGlobals.myFloID===floGlobals.adminID;let showingFloID=!0;setInterval((()=>{getRef("user_profile_id").textContent=showingFloID?floGlobals.myBtcID:floGlobals.myFloID,showingFloID=!showingFloID}),1e4);try{if(floGlobals.isSubAdmin){const promises=[];for(const category in floGlobals.taskCategories)floGlobals.appObjects[category]||(console.log("resetting",category),floGlobals.appObjects[category]={tasks:[]},promises.push(floCloudAPI.resetObjectData(category)));promises.push(floCloudAPI.requestGeneralData("taskApplications")),await Promise.all(promises);const taskApplications=floDapps.getNextGeneralData("taskApplications","0");floGlobals.applications={};for(const application in taskApplications){const{message:{taskID:taskID},senderID:senderID}=taskApplications[application];floGlobals.applications[taskID]||(floGlobals.applications[taskID]=new Set),floGlobals.applications[taskID].add(senderID)}}else if(floGlobals.isAdmin);else{floGlobals.applications=new Set;const promises=[floCloudAPI.requestGeneralData("taskApplications",{senderID:[floGlobals.myFloID,floGlobals.myBtcID]}),floCloudAPI.requestGeneralData("userProfile",{senderID:[floGlobals.myFloID,floGlobals.myBtcID]})];await Promise.all(promises);const taskApplications=floDapps.getNextGeneralData("taskApplications","0");for(const application in taskApplications){const{message:{taskID:taskID}}=taskApplications[application];(floGlobals.appObjects.rmInterns.tasks||[]).some((task=>task.id===taskID))&&floGlobals.applications.add(taskID)}const userProfile=floDapps.getNextGeneralData("userProfile","0");floGlobals.userProfile=Object.values(userProfile).at(-1)?.message.encryptedData}["#/landing","#/sign_in","#/sign_up"].includes(window.location.hash)?(history.replaceState(null,null,"#/home"),router.routeTo("home")):router.routeTo(window.location.hash)}catch(err){console.error(err)}})).catch((error=>console.error(error)))})); \ No newline at end of file