Comparing version 1.15.2 to 1.15.3
riot.tag("rg-alert",'<div each="{ opts.alerts }" class="alert { type }" onclick="{ onclick }"> <a class="close" aria-label="Close" onclick="{ parent.remove }" if="{ dismissable != false }"> <span aria-hidden="true">×</span> </a> <div class="body"> { msg } </div> </div>','rg-alert , [riot-tag="rg-alert"] { font-size: 0.9em; position: relative; top: 0; right: 0; left: 0; width: 100%; } rg-alert .alert, [riot-tag="rg-alert"] .alert{ position: relative; margin-bottom: 15px; } rg-alert .body, [riot-tag="rg-alert"] .body{ padding: 15px 35px 15px 15px; } rg-alert .close, [riot-tag="rg-alert"] .close{ position: absolute; top: 50%; right: 20px; line-height: 12px; margin-top: -6px; font-size: 18px; border: 0; background-color: transparent; color: rgba(0, 0, 0, 0.5); cursor: pointer; outline: none; } rg-alert .danger, [riot-tag="rg-alert"] .danger{ color: #8f1d2e; background-color: #ffced8; } rg-alert .information, [riot-tag="rg-alert"] .information{ color: #31708f; background-color: #d9edf7; } rg-alert .success, [riot-tag="rg-alert"] .success{ color: #2d8f40; background-color: #ccf7d4; } rg-alert .warning, [riot-tag="rg-alert"] .warning{ color: #c06329; background-color: #f7dfd0; }',function(opts){var _this=this;this.on("update",function(){opts.alerts.forEach(function(alert){alert.id=Math.random().toString(36).substr(2,8);if(!alert.timer&&alert.timeout){alert.startTimer=function(){alert.timer=window.setTimeout(function(){opts.alerts.splice(opts.alerts.indexOf(alert),1);if(alert.onclose)alert.onclose();_this.update()},alert.timeout)};alert.startTimer()}})});this.remove=function(e){e.stopPropagation();if(e.item.onclose)e.item.onclose();window.clearTimeout(e.item.timer);opts.alerts.splice(opts.alerts.indexOf(e.item),1)}});riot.tag("rg-autocomplete",'<div class="container { open: opened }" riot-style="width: { width }"> <input type="{ opts.type || \'text\' }" name="textbox" placeholder="{ opts.placeholder }" onkeydown="{ handleKeys }" oninput="{ filterItems }" onfocus="{ filterItems }"> <div class="dropdown { open: opened }" show="{ opened }"> <div class="list"> <ul> <li each="{ filteredItems }" onclick="{ parent.select }" class="item { active: active }"> { text } </li> </ul> </div> </div> </div>','rg-autocomplete .container, [riot-tag="rg-autocomplete"] .container{ position: relative; display: inline-block; cursor: pointer; } rg-autocomplete .container.open, [riot-tag="rg-autocomplete"] .container.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-autocomplete input, [riot-tag="rg-autocomplete"] input{ font-size: 1em; padding: 10px; border: 1px solid #D3D3D3; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; outline: none; } rg-autocomplete .container.open input, [riot-tag="rg-autocomplete"] .container.open input{ } rg-autocomplete .dropdown, [riot-tag="rg-autocomplete"] .dropdown{ position: relative; background-color: white; border: 1px solid #D3D3D3; border-top: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; overflow-y: auto; overflow-x: hidden; } rg-autocomplete .dropdown.open, [riot-tag="rg-autocomplete"] .dropdown.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-autocomplete ul, [riot-tag="rg-autocomplete"] ul,rg-autocomplete li, [riot-tag="rg-autocomplete"] li{ list-style: none; padding: 0; margin: 0; } rg-autocomplete li, [riot-tag="rg-autocomplete"] li{ padding: 10px; border-top: 1px solid #E8E8E8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-autocomplete li:first-child, [riot-tag="rg-autocomplete"] li:first-child{ border-top: 0; } rg-autocomplete li:hover, [riot-tag="rg-autocomplete"] li:hover{ background-color: #f3f3f3; } rg-autocomplete li.active, [riot-tag="rg-autocomplete"] li.active,rg-autocomplete li:hover.active, [riot-tag="rg-autocomplete"] li:hover.active{ background-color: #ededed; }',function(opts){var _this=this;this.opened=true;this.textbox.value=opts.value||"";this.filterItems=function(){_this.filteredItems=opts.items.filter(function(item){item.active=false;if(_this.textbox.value.length==0||item.text.toString().toLowerCase().indexOf(_this.textbox.value.toString().toLowerCase())>-1){return true}});if(_this.filteredItems.length>0){_this.opened=true}if(opts.onfilter){opts.onfilter()}_this.update()};this.handleKeys=function(e){var length=_this.filteredItems.length;if(length>0&&[13,38,40].indexOf(e.keyCode)>-1){_this.opened=true;e.preventDefault();var activeIndex=null;for(var i=0;i<length;i++){var item=_this.filteredItems[i];if(item.active){activeIndex=i;break}}if(activeIndex!=null)_this.filteredItems[activeIndex].active=false;if(e.keyCode==38){if(activeIndex==null||activeIndex==0)_this.filteredItems[length-1].active=true;else _this.filteredItems[activeIndex-1].active=true}else if(e.keyCode==40){if(activeIndex==null||activeIndex==length-1)_this.filteredItems[0].active=true;else _this.filteredItems[activeIndex+1].active=true}else if(e.keyCode==13&&activeIndex!=null)_this.select({item:_this.filteredItems[activeIndex]})}return true};this.select=function(item){item=item.item;if(opts.onselect)opts.onselect(item);_this.textbox.value=item.text;_this.opened=false};this.closeDropdown=function(e){if(!_this.root.contains(e.target)){if(opts.onclose&&_this.opened)opts.onclose();_this.opened=false;_this.update()}};this.on("mount",function(){document.addEventListener("click",_this.closeDropdown);document.addEventListener("focus",_this.closeDropdown,true);_this.width=_this.textbox.getBoundingClientRect().width+"px";var dd=_this.root.querySelector(".dropdown");dd.style.width=_this.width;dd.style.position="absolute";_this.opened=opts.opened;_this.update()});this.on("unmount",function(){document.removeEventListener("click",_this.closeDropdown);document.removeEventListener("focus",_this.closeDropdown,true)})});riot.tag("rg-behold",'<div class="controls"> <input type="range" class="ranger" name="diff" value="0" min="0" max="1" step="0.01" oninput="{ updateDiff }" onchange="{ updateDiff }"> </div> <div class="images"> <div class="image"> <img class="image-2" riot-src="{ opts.image2 }"> </div> <div class="image fallback"> <img class="image-1" riot-src="{ opts.image1 }"> </div> </div>','rg-behold .controls, [riot-tag="rg-behold"] .controls{ padding: 10px; background-color: #ededed; border: 1px solid #d3d3d3; margin-bottom: 20px; text-align: center; } rg-behold .ranger, [riot-tag="rg-behold"] .ranger{ width: 90%; max-width: 300px; } rg-behold .images, [riot-tag="rg-behold"] .images{ position: relative; } rg-behold .image, [riot-tag="rg-behold"] .image{ position: absolute; width: 100%; text-align: center; } rg-behold .image img, [riot-tag="rg-behold"] .image img{ max-width: 90%; }',function(opts){var _this=this;opts.mode=opts.mode||"fade";var image1,image2,fallback;this.on("mount",function(){image1=_this.root.querySelector(".image-1");image2=_this.root.querySelector(".image-2");fallback=typeof image1.style.webkitClipPath=="undefined";if(opts.mode=="fade"){_this.root.querySelector(".controls").style.direction="rtl";_this.diff.value=1}updateDiff()});updateDiff=function(e){if(opts.mode=="fade"){image1.style.opacity=_this.diff.value}else if(opts.mode=="swipe"){if(!fallback){image1.style.clipPath=image1.style.webkitClipPath="inset(0 0 0 "+(image1.clientWidth*_this.diff.value-1)+"px)"}else{var fallbackImg=_this.root.querySelector(".fallback");fallbackImg.style.clip="rect(auto, auto, auto, "+fallbackImg.clientWidth*_this.diff.value+"px)"}}}});riot.tag("rg-bubble",'<div class="context"> <div class="bubble { visible: visible }"> { text } </div> <div class="content" onmouseover="{ showBubble }" onmouseout="{ hideBubble }" onclick="{ toggleBubble }"> <yield></yield> </div> </div>','rg-bubble .context, [riot-tag="rg-bubble"] .context,rg-bubble .content, [riot-tag="rg-bubble"] .content{ display: inline-block; position: relative; } rg-bubble .bubble, [riot-tag="rg-bubble"] .bubble{ position: absolute; display: block; top: -27px; left: 50%; -webkit-transform: translate3d(-50%, 0, 0); transform: translate3d(-50%, 0, 0); padding: 5px 10px; background-color: rgba(0, 0, 0, 0.8); color: white; text-align: center; font-size: 12px; line-height: 1; white-space: nowrap; opacity: 0; transition: opacity 0.1s, top 0.1s; } rg-bubble .visible, [riot-tag="rg-bubble"] .visible{ top: -30px; opacity: 1; } rg-bubble .bubble:after, [riot-tag="rg-bubble"] .bubble:after{ content: \'\'; position: absolute; display: block; bottom: -10px; left: 50%; -webkit-transform: translate3d(-50%, 0, 0); transform: translate3d(-50%, 0, 0); width: 0; height: 0; border: 5px solid rgba(0, 0, 0, 0); border-top-color: rgba(0, 0, 0, 0.9); }',function(opts){var _this=this;this.text=opts.text;this.visible=false;this.showBubble=function(){clearTimeout(_this.timer);_this.visible=true};this.hideBubble=function(){_this.timer=setTimeout(function(){_this.visible=false;_this.update()},1e3)};this.toggleBubble=function(){_this.visible=!_this.visible}});riot.tag("rg-code",'<div class="editor"></div>','rg-code .editor, [riot-tag="rg-code"] .editor{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }',function(opts){var _this=this;this.on("mount",function(){var editor=ace.edit(_this.root.querySelector(".editor"));if(opts.theme)editor.setTheme("ace/theme/"+opts.theme);if(opts.mode)editor.getSession().setMode("ace/mode/"+opts.mode);editor.getSession().setTabSize(opts.tabsize||2);if(opts.softtabs=="true")editor.getSession().setUseSoftTabs(true);if(opts.wordwrap=="true")editor.getSession().setUseWrapMode(true);if(opts.readonly=="true")editor.setReadOnly(true);editor.getSession().on("change",function(e){if(opts.onchange)opts.onchange(editor.getValue())});if(opts.src){(function(){var oReq=new XMLHttpRequest;oReq.onload=function(){editor.setValue(oReq.responseText,-1);_this.update()};oReq.open("get",opts.src,true);oReq.send()})()}else{editor.setValue(opts.code)}})});riot.tag("rg-context-menu-item",'<div class="item { inactive: opts.inactive }" onclick="{ selectItem }"> <yield></yield> </div>',function(opts){var _this=this;this.selectItem=function(){if(!opts.inactive){if(opts.onselect)opts.onselect(opts);_this.parent.opts.menu.opened=false;_this.parent.update()}}});riot.tag("rg-context-menu-raw","<span></span>",function(opts){var _this=this;this.on("mount",function(){_this.root.innerHTML=opts.content})});riot.tag("rg-context-menu",'<div class="dropdown" show="{ opts.menu.opened }"> <div class="list"> <div each="{ opts.menu.items }" class="item { inactive: inactive }" onclick="{ selectItem }"> <rg-context-menu-raw if="{ content && !text }" content="{ content }"></rg-context-menu-raw> <span if="{ text }">{ text }</span> </div> <yield></yield> </div> </div>','rg-context-menu .dropdown, [riot-tag="rg-context-menu"] .dropdown{ position: absolute; background-color: white; border: 1px solid #D3D3D3; border-top: 0; text-align: left; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; z-index: 1; } rg-context-menu .item, [riot-tag="rg-context-menu"] .item{ cursor: pointer; padding: 10px; border-top: 1px solid #E8E8E8; background-color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-context-menu .item:hover, [riot-tag="rg-context-menu"] .item:hover{ background-color: #f3f3f3; } rg-context-menu .item.inactive, [riot-tag="rg-context-menu"] .item.inactive{ color: #8a8a8a; font-style: italic; } rg-context-menu .item.inactive:hover, [riot-tag="rg-context-menu"] .item.inactive:hover{ background-color: #fff; }',function(opts){var _this2=this;opts.menu=opts.menu||{};var handleClickOutside=function handleClickOutside(e){if(!_this2.root.contains(e.target)){if(opts.menu.onclose&&opts.menu.opened)opts.menu.onclose(e);opts.menu.opened=false;_this2.update()}};var openMenu=function openMenu(e){e.preventDefault();if(opts.menu.onopen)opts.menu.onopen(e);opts.menu.opened=true;_this2.update();var x=e.pageX;var y=e.pageY;var dd=_this2.root.querySelector(".dropdown");var ddRect=dd.getBoundingClientRect();if(x>window.innerWidth+window.scrollX-ddRect.width)x=window.innerWidth+window.scrollX-ddRect.width;dd.style.left=x+"px";if(y>window.innerHeight+window.scrollY-ddRect.height)y=window.innerHeight+window.scrollY-ddRect.height;dd.style.top=y+"px";_this2.update()};this.on("mount",function(){document.addEventListener("click",handleClickOutside);var targets=document.querySelectorAll("[rg-context-menu]");for(var i=0,target;target=targets[i];i++){if(target.attributes["rg-context-menu"].value==opts.id)target.addEventListener("contextmenu",openMenu);else target.addEventListener("contextmenu",_this.closeMenu)}});this.on("unmount",function(){document.removeEventListener("click",handleClickOutside);var targets=document.querySelectorAll("[rg-context-menu]");for(var i=0,target;target=targets[i];i++){if(target.attributes["rg-context-menu"].value==opts.id)target.removeEventListener("contextmenu",openMenu);else target.removeEventListener("contextmenu",_this.closeMenu)}});this.closeMenu=function(){opts.menu.opened=false;_this2.update()};this.selectItem=function(e){if(!e.item.inactive){if(e.item.onselect)e.item.onselect(e.item);opts.menu.opened=false}}});riot.tag("rg-datepicker",'{ opts.months} <div class="container { open: opened }"> <input type="text" onclick="{ show }" value="{ date.format(opts.format || \'LL\') }" readonly> <div class="calendar" show="{ opened }"> <div class="grid grid-row" if="{ opts.years != \'false\' }"> <div class="selector" onclick="{ prevYear }">‹</div> <span class="year">{ date.format(\'YYYY\') }</span> <div class="selector" onclick="{ nextYear }">›</div> </div> <div class="grid grid-row" if="{ opts.years == \'false\' }"> <span class="year fill">{ date.format(\'YYYY\') }</span> </div> <div class="grid grid-row" if="{ opts.months != \'false\' }"> <div class="selector" onclick="{ prevMonth }">‹</div> <span class="month">{ date.format(\'MMMM\') }</span> <div class="selector" onclick="{ nextMonth }">›</div> </div> <div class="grid grid-row" if="{ opts.months == \'false\' }"> <span class="month fill">{ date.format(\'MMMM\') }</span> </div> <div class="grid grid-row"> <span class="day-name" each="{ day in dayNames }">{ day }</span> </div> <div class="grid grid-wrap"> <div each="{ day in days }" onclick="{ changeDate }" class="date { in: day.inMonth, selected: day.selected, today: day.today }"> { day.date.format(\'DD\') } </div> </div> <div class="grid grid-row"> <a class="shortcut" onclick="{ setToday }">Today</a> </div> </div> </div>','rg-datepicker .container, [riot-tag="rg-datepicker"] .container{ position: relative; display: inline-block; cursor: pointer; } rg-datepicker input, [riot-tag="rg-datepicker"] input{ font-size: 1em; padding: 10px; border: 1px solid #D3D3D3; cursor: pointer; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; outline: none; } rg-datepicker .calendar, [riot-tag="rg-datepicker"] .calendar{ position: absolute; text-align: center; background-color: white; border: 1px solid #D3D3D3; padding: 5px; width: 330px; margin-top: 10px; left: 50%; -webkit-transform: translateX(-50%); -moz-transform: translateX(-50%); -ms-transform: translateX(-50%); -o-transform: translateX(-50%); transform: translateX(-50%); -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-datepicker .grid, [riot-tag="rg-datepicker"] .grid{ display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-align-items: center; -ms-flex-align: center; align-items: center; } rg-datepicker .grid-wrap, [riot-tag="rg-datepicker"] .grid-wrap{ width: 100%; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; } rg-datepicker .grid-row, [riot-tag="rg-datepicker"] .grid-row{ height: 35px; } rg-datepicker .selector, [riot-tag="rg-datepicker"] .selector{ font-size: 2em; font-weight: 100; padding: 0; -webkit-flex: 0 0 15%; -ms-flex: 0 0 15%; flex: 0 0 15%; } rg-datepicker .year, [riot-tag="rg-datepicker"] .year,rg-datepicker .month, [riot-tag="rg-datepicker"] .month{ text-transform: uppercase; font-weight: normal; -webkit-flex: 0 0 70%; -ms-flex: 0 0 70%; flex: 0 0 70%; } rg-datepicker .fill, [riot-tag="rg-datepicker"] .fill{ -webkit-flex: 0 0 100%; -ms-flex: 0 0 100%; flex: 0 0 100%; } rg-datepicker .day-name, [riot-tag="rg-datepicker"] .day-name{ font-weight: bold; -webkit-flex: 0 0 14.28%; -ms-flex: 0 0 14.28%; flex: 0 0 14.28%; } rg-datepicker .date, [riot-tag="rg-datepicker"] .date{ -webkit-flex: 0 0 14.28%; -ms-flex: 0 0 14.28%; flex: 0 0 14.28%; padding: 10px; border-radius: 100%; box-sizing: border-box; font-size: 0.8em; font-weight: normal; border: 2px solid transparent; color: #cacaca; } rg-datepicker .date:hover, [riot-tag="rg-datepicker"] .date:hover{ background-color: #f3f3f3; } rg-datepicker .date.in, [riot-tag="rg-datepicker"] .date.in{ color: inherit; } rg-datepicker .today, [riot-tag="rg-datepicker"] .today{ border-color: #ededed; } rg-datepicker .selected, [riot-tag="rg-datepicker"] .selected,rg-datepicker .selected:hover, [riot-tag="rg-datepicker"] .selected:hover{ background-color: #ededed; border-color: #dedede; } rg-datepicker .shortcut, [riot-tag="rg-datepicker"] .shortcut{ -webkit-flex: 0 0 100%; -ms-flex: 0 0 100%; flex: 0 0 100%; color: #6495ed; }',function(opts){var _this=this;this.date=moment(opts.date||new Date);var handleClickOutside=function handleClickOutside(e){if(!_this.root.contains(e.target)&&_this.opened){if(opts.onclose)opts.onclose(_this.date);_this.opened=false;_this.update()}};var buildCalendar=function buildCalendar(){var cursor=moment(_this.date);var end=moment(cursor);cursor.startOf("month");cursor.day(0);end.endOf("month");end.day(6);_this.dayNames=[];_this.days=[];while(cursor.isBefore(end)){if(_this.dayNames.length<7)_this.dayNames.push(cursor.format("dd"));_this.days.push({date:moment(cursor),selected:_this.date.isSame(cursor,"day"),today:moment().isSame(cursor,"day"),inMonth:_this.date.isSame(cursor,"month")});cursor=cursor.add(1,"days")}_this.opts.date=_this.date.toDate();_this.update()};this.on("mount",function(){document.addEventListener("click",handleClickOutside)});this.on("unmount",function(){document.removeEventListener("click",handleClickOutside)});this.changeDate=function(e){_this.date=e.item.day.date;if(opts.onselect)opts.onselect(_this.date);buildCalendar()};this.setToday=function(){_this.date=opts.date=moment();if(opts.onselect)opts.onselect(_this.date);buildCalendar()};this.prevYear=function(){_this.date.subtract(1,"year");buildCalendar()};this.nextYear=function(){_this.date.add(1,"year");buildCalendar()};this.prevMonth=function(){_this.date.subtract(1,"month");buildCalendar()};this.nextMonth=function(){_this.date.add(1,"month");buildCalendar()};this.show=function(){if(opts.onopen)opts.onopen();buildCalendar();_this.opened=true}});riot.tag("rg-ga","",function(opts){(function(i,s,o,g,r,a,m){i["GoogleAnalyticsObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date;a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)})(window,document,"script","//www.google-analytics.com/analytics.js","ga");ga("create",opts.property,"auto");ga("send","pageview")});riot.tag("rg-include","{{ responseText }}",function(opts){var _this=this;var oReq=new XMLHttpRequest;oReq.onload=function(){if(opts.unsafe)_this.root.innerHTML=oReq.responseText;else _this.responseText=oReq.responseText;_this.update()};oReq.open("get",opts.src,opts.async||true);oReq.send()});riot.tag("rg-loading",'<div class="overlay"></div> <div class="loading"> <div> <yield></yield> </div> <div if="{ opts.spinner == \'true\' }"> <svg width="80px" height="80px" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid" class="uil-default"> <rect x="0" y="0" width="80" height="80" fill="none" class="bk"></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(0 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(45 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.0625s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(90 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.125s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(135 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.1875s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(180 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.25s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(225 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.3125s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(270 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.375s" repeatCount="indefinite"></animate></rect> <rect x="48.5" y="47" width="3" height="6" rx="0" ry="0" fill="#ffffff" transform="rotate(315 50 50) translate(0 -10)"><animate attributeName="opacity" from="1" to="0" dur="0.5s" begin="0.4375s" repeatCount="indefinite"></animate></rect> </svg> </div> </div>','rg-loading .overlay, [riot-tag="rg-loading"] .overlay{ position: absolute; width: 100%; height: 100%; top: 0; right: 0; bottom: 0; left: 0; background-color: rgba(0, 0, 0, 0.8); z-index: 200; } rg-loading .loading, [riot-tag="rg-loading"] .loading{ position: absolute; width: 95%; max-width: 420px; top: 50%; left: 50%; -webkit-transform: translate3d(-50%, -50%, 0); -moz-transform: translate3d(-50%, -50%, 0); -ms-transform: translate3d(-50%, -50%, 0); -o-transform: translate3d(-50%, -50%, 0); transform: translate3d(-50%, -50%, 0); background-color: transparent; color: #fff; text-align: center; z-index: 201; }',function(opts){});var RgMap=riot.observable();RgMap.initialize=function(){RgMap.trigger("initializeRgMap")};riot.tag("rg-map",'<div class="rg-map"></div>','rg-map .rg-map, [riot-tag="rg-map"] .rg-map{ margin: 0; padding: 0; width: 100%; height: 100%; } rg-map .rg-map img, [riot-tag="rg-map"] .rg-map img{ max-width: inherit; }',function(opts){var _this=this;var defaultOptions={center:{lat:53.806,lng:-1.535},zoom:5};var mapOptions=opts.map||defaultOptions;RgMap.on("initializeRgMap",function(){var map=new google.maps.Map(_this.root.querySelector(".rg-map"),mapOptions)});(function(){if(!document.getElementById("gmap_script")){var script=document.createElement("script");script.setAttribute("id","gmap_script");script.type="text/javascript";script.src="https://maps.googleapis.com/maps/api/js?sensor=false&callback=RgMap.initialize";document.body.appendChild(script)}})()});riot.tag("rg-markdown",'<div class="markdown"></div>',function(opts){var _this=this;var reader=new commonmark.Parser;var writer=new commonmark.HtmlRenderer;var markItDown=function markItDown(content){var parsed=reader.parse(content);_this.root.innerHTML=writer.render(parsed)};if(opts.src){var oReq=new XMLHttpRequest;oReq.onload=function(){markItDown(oReq.responseText);_this.update()};oReq.open("get",opts.src,opts.async||true);oReq.send()}else{markItDown(opts.content)}});riot.tag("rg-modal",'<div class="overlay { expanded: opts.modal.visible, ghost: opts.modal.ghost }" onclick="{ close }"></div> <div class="modal { ghost: opts.modal.ghost }" if="{ opts.modal.visible }"> <header class="header"> <button if="{ opts.modal.close != false }" type="button" class="close" aria-label="Close" onclick="{ close }"> <span aria-hidden="true">×</span> </button> <h3 class="heading">{ opts.modal.heading }</h3> </header> <div class="body"> <yield></yield> </div> <footer class="footer"> <button class="button" each="{ opts.modal.buttons }" type="button" onclick="{ action }" riot-style="{ style }"> { text } </button> <div class="clear"></div> </footer> </div>','rg-modal .overlay, [riot-tag="rg-modal"] .overlay,rg-modal .overlay.ghost, [riot-tag="rg-modal"] .overlay.ghost{ position: fixed; top: 0; left: -100%; right: 0; bottom: 0; width: 100%; height: 100%; background-color: transparent; cursor: pointer; -webkit-transition: background-color 0.8s ease, left 0s 0.8s; -moz-transition: background-color 0.8s ease, left 0s 0.8s; -ms-transition: background-color 0.8s ease, left 0s 0.8s; -o-transition: background-color 0.8s ease, left 0s 0.8s; transition: background-color 0.8s ease, left 0s 0.8s; z-index: 50; } rg-modal .overlay.expanded, [riot-tag="rg-modal"] .overlay.expanded,rg-modal .overlay.ghost.expanded, [riot-tag="rg-modal"] .overlay.ghost.expanded{ left: 0; background-color: rgba(0, 0, 0, 0.8); -webkit-transition: background-color 0.8s ease, left 0s; -moz-transition: background-color 0.8s ease, left 0s; -ms-transition: background-color 0.8s ease, left 0s; -o-transition: background-color 0.8s ease, left 0s; transition: background-color 0.8s ease, left 0s; } rg-modal .modal, [riot-tag="rg-modal"] .modal,rg-modal .modal.ghost, [riot-tag="rg-modal"] .modal.ghost{ position: fixed; width: 95%; max-width: 500px; font-size: 1.1em; top: 50%; left: 50%; -webkit-transform: translate3d(-50%, -75%, 0); -moz-transform: translate3d(-50%, -75%, 0); -ms-transform: translate3d(-50%, -75%, 0); -o-transform: translate3d(-50%, -75%, 0); transform: translate3d(-50%, -75%, 0); background-color: white; color: #252519; z-index: 101; } rg-modal .modal.ghost, [riot-tag="rg-modal"] .modal.ghost{ background-color: transparent; color: white; } rg-modal .header, [riot-tag="rg-modal"] .header{ position: relative; text-align: center; } rg-modal .heading, [riot-tag="rg-modal"] .heading{ padding: 20px 20px 0 20px; margin: 0; font-size: 1.2em; } rg-modal .modal.ghost .heading, [riot-tag="rg-modal"] .modal.ghost .heading{ color: white; } rg-modal .close, [riot-tag="rg-modal"] .close{ position: absolute; top: 5px; right: 5px; padding: 0; height: 25px; width: 25px; line-height: 25px; font-size: 25px; border: 0; background-color: transparent; color: #ef424d; cursor: pointer; outline: none; } rg-modal .modal.ghost .close, [riot-tag="rg-modal"] .modal.ghost .close{ color: white; } rg-modal .body, [riot-tag="rg-modal"] .body{ padding: 20px; } rg-modal .footer, [riot-tag="rg-modal"] .footer{ padding: 0 20px 20px 20px; } rg-modal .button, [riot-tag="rg-modal"] .button{ float: right; padding: 10px; margin: 0 5px 0 0; border: none; font-size: 0.9em; text-transform: uppercase; cursor: pointer; outline: none; background-color: white; } rg-modal .modal.ghost .button, [riot-tag="rg-modal"] .modal.ghost .button{ color: white; background-color: transparent; } rg-modal .clear, [riot-tag="rg-modal"] .clear{ clear: both; }',function(opts){this.close=function(e){opts.modal.visible=false;if(opts.modal.onclose)opts.modal.onclose(e)}});riot.tag("rg-phone-sim",'<div class="emulator"> <iframe class="screen" riot-src="{ opts.src }"></iframe> </div>','rg-phone-sim .emulator, [riot-tag="rg-phone-sim"] .emulator{ position: relative; width: 365px; height: 792px; background-image: url(\'\'); background-repeat: no-repeat; background-position: center; background-size: cover; } rg-phone-sim .screen, [riot-tag="rg-phone-sim"] .screen{ position: absolute; top: 105px; left: 22px; background-color: white; width: 320px; height: 568px; border: 0; }',function(opts){}); | ||
riot.tag("rg-placeholdit",'<img riot-src="https://placeholdit.imgix.net/~text?bg={ background }&txtclr={ color }&txt={ text }&txtsize={ textSize }&w={ width }&h={ height }&fm={ format }">',function(opts){this.width=opts.width||450;this.height=opts.height||250;this.background=opts["background-color"]||"f01e52";this.color=opts.color||"fff";this.text=opts.text||this.width+" x "+this.height;this.textSize=opts["font-size"]||"30";this.format=opts.format||"png"});"use strict";(function(){var _states=[];var findStateByName=function findStateByName(name){return _states.find(function(state){if(state.name==name)return state})};var findStateByUrl=function findStateByUrl(url){return _states.find(function(state){if(state.url==url)return state})};var handlePop=function handlePop(e){if(e.state)router.go(e.state,true)};var changeState=function changeState(state,popped){if(typeof history.pushState!="undefined"&&state.history!=false){if(!history.state||history.state.name!=state.name&&!popped){var url=state.url?"#!/"+state.url:null;history.pushState(state.name,null,url)}}var prevState=Object.assign({},router.current);router.current=state;router.trigger("go",state,prevState)};var router={add:function add(state){if(!state||!state.name){throw"Please specify a state name";return}var _state=findStateByName(state);if(_state)_state=state;else _states.push(state);router.trigger("add",_state)},remove:function remove(name){var _state=undefined;_states=_states.filter(function(state){if(state.name!=name)return state;else _state=state});router.trigger("remove",_state)},go:function go(name,popped){if(!router.active||!name)return;var _state=findStateByName(name);if(!_state){throw"State '"+name+"' has not been configured";return}var names=name.split(".");names=names.map(function(name,i){if(i>0){return names.slice(0,i).join(".")+"."+name}else{return name}});names.forEach(function(name,i){if(i<names.length){var _parent=findStateByName(name);_state=Object.assign({},_state,_parent)}});if(typeof _state.resolve=="function"){var promise=_state.resolve();if(typeof promise.then=="function")promise.then(function(){return changeState(_state,popped)})}else{changeState(_state,popped)}},start:function start(){if(window.location.hash){var _state=findStateByUrl(window.location.hash.replace("#!/",""));if(_state)router.go(_state.name)}window.addEventListener("popstate",handlePop);router.active=true;router.trigger("start")},stop:function stop(){window.addEventListener("popstate",handlePop);router.active=false;router.trigger("stop")},current:undefined,active:false};riot.observable(router);riot.mixin("rg.router",{init:function init(){this.router.on("go",this.update)},router:router});if(!window.rg)window.rg={};window.rg.router=router})();riot.tag("rg-select",'<div class="container { open: opened }" riot-style="width: { width }"> <input type="text" class="field { open: opened}" onkeydown="{ handleKeys }" onclick="{ toggle }" value="{ fieldText || opts.placeholder }" readonly> <div class="dropdown" show="{ opened }"> <div class="filter"> <input type="text" name="filter" class="filter-box" placeholder="{ opts[\'filter-placeholder\'] || \'Filter\' }" onkeydown="{ handleKeys }" oninput="{ filterItems }"> </div> <div class="list"> <ul> <li each="{ filteredItems }" onclick="{ parent.select }" class="item { selected: selected, disabled: disabled, active: active }"> { text } </li> </ul> </div> </div> </div>','rg-select .container, [riot-tag="rg-select"] .container{ position: relative; display: inline-block; cursor: pointer; } rg-select .container.open, [riot-tag="rg-select"] .container.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-select .field, [riot-tag="rg-select"] .field{ width: 100%; padding: 10px; background-color: white; border: 1px solid #D3D3D3; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 1em; line-height: normal; outline: 0; } rg-select .down-arrow, [riot-tag="rg-select"] .down-arrow{ float: right; } rg-select .dropdown, [riot-tag="rg-select"] .dropdown{ position: relative; width: 100%; background-color: white; border: 1px solid #D3D3D3; border-top: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } rg-select .container.open .dropdown, [riot-tag="rg-select"] .container.open .dropdown{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-select .filter-box, [riot-tag="rg-select"] .filter-box{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 100%; padding: 10px; font-size: 0.9rem; border: 0; outline: none; color: #555; } rg-select ul, [riot-tag="rg-select"] ul,rg-select li, [riot-tag="rg-select"] li{ list-style: none; padding: 0; margin: 0; } rg-select li, [riot-tag="rg-select"] li{ padding: 10px; border-top: 1px solid #E8E8E8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-select .selected, [riot-tag="rg-select"] .selected{ font-weight: bold; background-color: #f8f8f8; } rg-select li:hover, [riot-tag="rg-select"] li:hover{ background-color: #f3f3f3; } rg-select li.active, [riot-tag="rg-select"] li.active,rg-select li:hover.active, [riot-tag="rg-select"] li:hover.active{ background-color: #ededed; }',function(opts){var _this=this;this.opened=true;var handleClickOutside=function handleClickOutside(e){if(!_this.root.contains(e.target)){if(opts.onclose&&_this.opened)opts.onclose();_this.opened=false;_this.update()}};this.handleKeys=function(e){if(e.keyCode==13&&!_this.opened){_this.toggle();return true}var length=_this.filteredItems.length;if(length>0&&[13,38,40].indexOf(e.keyCode)>-1){e.preventDefault();var activeIndex=null;for(var i=0;i<length;i++){var item=_this.filteredItems[i];if(item.active){activeIndex=i;break}}if(activeIndex!=null)_this.filteredItems[activeIndex].active=false;if(e.keyCode==38){if(activeIndex==null||activeIndex==0)_this.filteredItems[length-1].active=true;else _this.filteredItems[activeIndex-1].active=true}else if(e.keyCode==40){if(activeIndex==null||activeIndex==length-1)_this.filteredItems[0].active=true;else _this.filteredItems[activeIndex+1].active=true}else if(e.keyCode==13&&activeIndex!=null){_this.select({item:_this.filteredItems[activeIndex]})}}return true};this.toggle=function(){_this.opened=!_this.opened;if(opts.onopen&&_this.opened)opts.onopen();else if(opts.onclose&&!_this.opened)opts.onclose()};this.filterItems=function(){_this.filteredItems=opts.options.filter(function(item){item.active=false;var filterField=item[opts["filter-on"]||"text"];if(_this.filter.value.length==0||filterField.toString().toLowerCase().indexOf(_this.filter.value.toString().toLowerCase())>-1)return true});if(opts.onfilter)opts.onfilter();_this.update()};this.select=function(item){item=item.item;opts.options.forEach(function(item){return item.selected=false});item.selected=true;if(opts.onselect)opts.onselect(item);_this.fieldText=item.text;_this.opened=false};this.on("mount",function(){_this.filterItems();opts.options.forEach(function(item,i){item.index=i;if(item.selected)_this.select({item:item})});document.addEventListener("click",handleClickOutside);var dd=_this.root.querySelector(".dropdown");_this.width=dd.getBoundingClientRect().width+20+"px";dd.style.position="absolute";_this.opened=opts.opened;_this.update()});this.on("unmount",function(){return document.removeEventListener("click",handleClickOutside)})});riot.tag("rg-sidemenu",'<div class="overlay { expanded: opts.sidemenu.expanded }" onclick="{ close }"></div> <div class="sidemenu { expanded: opts.sidemenu.expanded }"> <h4 class="header">{ opts.sidemenu.header }</h4> <ul class="items"> <li class="item { active: active }" each="{ opts.sidemenu.items }" onclick="{ selected }"> { text } </li> </ul> <div class="body"> <yield></yield> </div> </div>','rg-sidemenu .overlay, [riot-tag="rg-sidemenu"] .overlay{ position: fixed; top: 0; left: -100%; right: 0; bottom: 0; width: 100%; height: 100%; background-color: transparent; cursor: pointer; -webkit-transition: background-color 0.8s ease, left 0s 0.8s; -moz-transition: background-color 0.8s ease, left 0s 0.8s; -ms-transition: background-color 0.8s ease, left 0s 0.8s; -o-transition: background-color 0.8s ease, left 0s 0.8s; transition: background-color 0.8s ease, left 0s 0.8s; z-index: 50; } rg-sidemenu .overlay.expanded, [riot-tag="rg-sidemenu"] .overlay.expanded{ left: 0; background-color: rgba(0, 0, 0, 0.8); -webkit-transition: background-color 0.8s ease, left 0s; -moz-transition: background-color 0.8s ease, left 0s; -ms-transition: background-color 0.8s ease, left 0s; -o-transition: background-color 0.8s ease, left 0s; transition: background-color 0.8s ease, left 0s; } rg-sidemenu .sidemenu, [riot-tag="rg-sidemenu"] .sidemenu{ position: fixed; top: 0; left: 0; height: 100%; width: 260px; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; background-color: black; color: white; -webkit-transform: translate3d(-100%, 0, 0); -moz-transform: translate3d(-100%, 0, 0); -ms-transform: translate3d(-100%, 0, 0); -o-transform: translate3d(-100%, 0, 0); transform: translate3d(-100%, 0, 0); -webkit-transition: -webkit-transform 0.5s ease; -moz-transition: -moz-transform 0.5s ease; -ms-transition: -ms-transform 0.5s ease; -o-transition: -o-transform 0.5s ease; transition: transform 0.5s ease; z-index: 51; } rg-sidemenu .sidemenu.expanded, [riot-tag="rg-sidemenu"] .sidemenu.expanded{ -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); -o-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } rg-sidemenu .header, [riot-tag="rg-sidemenu"] .header{ padding: 1.2rem; margin: 0; text-align: center; color: white; } rg-sidemenu .items, [riot-tag="rg-sidemenu"] .items{ padding: 0; margin: 0; list-style: none; } rg-sidemenu .item, [riot-tag="rg-sidemenu"] .item{ padding: 1rem 0.5rem; box-sizing: border-box; border-top: 1px solid #1a1a1a; color: white; } rg-sidemenu .item:last-child, [riot-tag="rg-sidemenu"] .item:last-child{ border-bottom: 1px solid #1a1a1a; } rg-sidemenu .item:hover, [riot-tag="rg-sidemenu"] .item:hover{ cursor: pointer; background-color: #2a2a2a; } rg-sidemenu .item.active, [riot-tag="rg-sidemenu"] .item.active{ cursor: pointer; background-color: #444; }',function(opts){this.close=function(){return opts.sidemenu.expanded=false};this.selected=function(item){item=item.item;opts.sidemenu.items.forEach(function(item){return item.active=false});item.active=true;if(item.action)item.action(item)}});riot.tag("rg-tag-heading-raw","<span></span>",function(opts){var _this=this;this.on("mount",function(){return _this.root.innerHTML=opts.content})});riot.tag("rg-tab-heading","<yield></yield>",'rg-tab-heading , [riot-tag="rg-tab-heading"] { display: none; }',function(opts){});riot.tag("rg-tab",'<div show="{ active }" class="tab"> <yield></yield> </div>',".tab { padding: 10px; }",function(opts){this.active=opts.active;this.disabled=opts.disabled});riot.tag("rg-tabs",'<div class="tabs"> <div class="headers"> <div each="{ tab in tabs }" class="header { active: tab.active, disabled: tab.disabled }" onclick="{ activate }"> <h4 class="heading" if="{ tab.opts.heading && !tab.heading }">{ tab.opts.heading }</h4> <div class="heading" if="{ tab.heading }"> <rg-tag-heading-raw content="{ tab.heading }"></rg-tag-heading-raw> </div> </div> </div> <yield></yield> </div>','rg-tabs .tabs, [riot-tag="rg-tabs"] .tabs{ background-color: white; } rg-tabs .headers, [riot-tag="rg-tabs"] .headers{ display: -webkit-flex; display: -ms-flexbox; display: flex; } rg-tabs .header, [riot-tag="rg-tabs"] .header{ -webkit-flex: 1; -ms-flex: 1; flex: 1; box-sizing: border-box; text-align: center; cursor: pointer; box-shadow: 0 -1px 0 0 #404040 inset; } rg-tabs .heading, [riot-tag="rg-tabs"] .heading{ padding: 10px; margin: 0; } rg-tabs .header.active, [riot-tag="rg-tabs"] .header.active{ background-color: #404040; } rg-tabs .header.active .heading, [riot-tag="rg-tabs"] .header.active .heading{ color: white; } rg-tabs .header.disabled .heading, [riot-tag="rg-tabs"] .header.disabled .heading{ color: #888; }',function(opts){var _this=this;this.onopen=opts.onopen;this.tabs=this.tags["rg-tab"];var deselectTabs=function deselectTabs(){return _this.tabs.forEach(function(tab){return tab.active=false})};this.on("mount",function(){var activeTab=false;_this.tabs.forEach(function(tab,i){tab.index=i;var tabHeading=tab.tags["rg-tab-heading"];if(tabHeading){if(Object.prototype.toString.call(tabHeading)!=="[object Array]")tab.heading=tabHeading.root.innerHTML}if(activeTab)tab.active=false;if(tab.active)activeTab=true});_this.update()});this.activate=function(e){tab=e.item.tab;if(!tab.disabled){deselectTabs();if(_this.onopen)_this.onopen(tab);tab.active=true}}});riot.tag("rg-tags",'<div class="container"> <span class="tags"> <span class="tag" each="{ opts.tags }" onclick="{ parent.removeTag }"> { text } <span class="close">×</span> </span> </span> <div class="input-container { open: opened }"> <input type="{ opts.type || \'text\' }" name="textbox" placeholder="{ opts.placeholder }" onkeydown="{ handleKeys }" oninput="{ filterItems }" onfocus="{ filterItems }"> <div class="dropdown { open: opened }" show="{ opened }"> <div class="list"> <ul> <li each="{ filteredItems }" onclick="{ parent.select }" class="item { active: active }"> { text } </li> </ul> </div> </div> </div> </div>','rg-tags .container, [riot-tag="rg-tags"] .container{ width: 100%; border: 1px solid #D3D3D3; background: white; text-align: left; padding: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } rg-tags .input-container, [riot-tag="rg-tags"] .input-container{ position: absolute; display: inline-block; cursor: pointer; } rg-tags input, [riot-tag="rg-tags"] input{ width: 100%; font-size: 1em; padding: 10px; border: 0; background-color: transparent; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; outline: none; } rg-tags .dropdown, [riot-tag="rg-tags"] .dropdown{ position: absolute; width: 100%; background-color: white; border: 1px solid #D3D3D3; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; overflow-y: auto; overflow-x: hidden; } rg-tags .dropdown.open, [riot-tag="rg-tags"] .dropdown.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-tags ul, [riot-tag="rg-tags"] ul,rg-tags li, [riot-tag="rg-tags"] li{ list-style: none; padding: 0; margin: 0; } rg-tags li, [riot-tag="rg-tags"] li{ padding: 10px; border-top: 1px solid #E8E8E8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-tags li:first-child, [riot-tag="rg-tags"] li:first-child{ border-top: 0; } rg-tags li:hover, [riot-tag="rg-tags"] li:hover{ background-color: #f3f3f3; } rg-tags li.active, [riot-tag="rg-tags"] li.active,rg-tags li:hover.active, [riot-tag="rg-tags"] li:hover.active{ background-color: #ededed; } rg-tags .tags, [riot-tag="rg-tags"] .tags{ display: inline-block; max-width: 70%; white-space: nowrap; overflow-y: hidden; overflow-x: auto; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } rg-tags .tag, [riot-tag="rg-tags"] .tag{ position: relative; display: inline-block; padding: 5px 20px 5px 5px; margin: 4px 5px; background-color: #444; color: #fff; cursor: pointer; } rg-tags .tag:hover, [riot-tag="rg-tags"] .tag:hover,rg-tags .tag:active, [riot-tag="rg-tags"] .tag:active{ background-color: #666; } rg-tags .close, [riot-tag="rg-tags"] .close{ position: absolute; right: 5px; top: 5px; color: rgba(255,255,255,0.7); }',function(opts){var _this=this;this.opened=true;this.textbox.value=opts.value||"";opts.items=opts.items||[];opts.tags=opts.tags||[];opts.tags.forEach(function(tag,i){return tag.index=i});this.filterItems=function(){_this.filteredItems=opts.items.filter(function(item){item.active=false;if(_this.textbox.value.length==0||item.text.toString().toLowerCase().indexOf(_this.textbox.value.toString().toLowerCase())>-1)return true});_this.opened=_this.filteredItems.length>0;if(opts.onfilter)opts.onfilter();_this.update()};this.handleKeys=function(e){var length=_this.filteredItems.length;if(length>0&&[13,38,40].indexOf(e.keyCode)>-1){_this.opened=true;e.preventDefault();var activeIndex=null;for(var i=0;i<length;i++){var item=_this.filteredItems[i];if(item.active){activeIndex=i;break}}if(activeIndex!=null)_this.filteredItems[activeIndex].active=false;if(e.keyCode==38){if(activeIndex==null||activeIndex==0)_this.filteredItems[length-1].active=true;else _this.filteredItems[activeIndex-1].active=true}else if(e.keyCode==40){if(activeIndex==null||activeIndex==length-1)_this.filteredItems[0].active=true;else _this.filteredItems[activeIndex+1].active=true}else if(e.keyCode==13&&activeIndex!=null){_this.select({item:_this.filteredItems[activeIndex]})}}if(e.keyCode==13){_this.addTag()}else if(e.keyCode==8&&_this.textbox.value==""&&opts.tags.length>0){var tag=opts.tags.pop();_this.textbox.value=tag.text}return true};this.addTag=function(item){var tag=item||{text:_this.textbox.value};if(tag.text.length>0){tag.index=opts.tags.length;opts.tags.push(tag);_this.textbox.value="";_this.filteredItems=opts.items;_this.opened=false}_this.update()};this.removeTag=function(e){opts.tags.splice(opts.tags.indexOf(e.item),1);_this.opened=false};this.select=function(item){item=item.item;if(opts.onselect)opts.onselect(item);_this.addTag(item)};this.closeDropdown=function(e){if(!_this.root.contains(e.target)){if(opts.onclose&&_this.opened)opts.onclose();_this.opened=false;_this.update()}};this.on("mount",function(){document.addEventListener("click",_this.closeDropdown);document.addEventListener("focus",_this.closeDropdown,true);_this.opened=opts.opened;_this.update()});this.on("unmount",function(){document.removeEventListener("click",_this.closeDropdown);document.removeEventListener("focus",_this.closeDropdown,true)});this.on("update",function(){var containerWidth=_this.root.querySelector(".container").getBoundingClientRect().width;var tagList=_this.root.querySelector(".tags");var tagListWidth=tagList.getBoundingClientRect().width;tagList.scrollLeft=Number.MAX_VALUE;var inputContainer=_this.root.querySelector(".input-container");inputContainer.style.width=containerWidth-tagListWidth+"px";_this.root.querySelector(".container").style.height=inputContainer.getBoundingClientRect().height+"px"})});riot.tag("rg-timepicker",'<rg-select placeholder="Select a time" filter-placeholder="Filter times" options="{ times }" onopen="{ opts.onopen }" onclose="{ opts.onclose }" onselect="{ opts.onselect }"> </rg-select>',function(opts){opts.time=opts.time||"now";if(opts.time=="now")opts.time=new Date;if(opts.min)opts.min=opts.min.split(":");if(opts.max)opts.max=opts.max.split(":");var step=parseInt(opts.step)||1;this.times=[];for(var i=0;i<1440;i++){if(i%step==0){var d=new Date(0);d.setHours(opts.time.getHours());d.setMinutes(opts.time.getMinutes());d=new Date(d.getTime()+i*6e4);if(opts.min){if(d.getHours()<opts.min[0])continue;if(d.getHours()==opts.min[0]&&d.getMinutes()<opts.min[1])continue}if(opts.max){if(d.getHours()>opts.max[0])continue;if(d.getHours()==opts.max[0]&&d.getMinutes()>opts.max[1])continue}var t={hours:d.getHours(),minutes:d.getMinutes()};var m=t.minutes;if(m<10)m="0"+m;if(opts.ampm){var ampm="am";var h=t.hours;if(h>=12){ampm="pm";h=h-12}if(h==0)h=12;t.text=h+":"+m+" "+ampm;t.period=ampm}else{var h=t.hours;if(h<10)h="0"+h;t.text=h+":"+m}this.times.push(t)}}});riot.tag("rg-toast",'<div class="toasts { opts.position }" if="{ opts.toasts.length > 0 }"> <div class="toast" each="{ opts.toasts }" onclick="{ parent.toastClicked }"> { text } </div> </div>','rg-toast .toasts, [riot-tag="rg-toast"] .toasts{ position: fixed; width: 250px; max-height: 100%; overflow-y: auto; background-color: transparent; z-index: 101; } rg-toast .toasts.topleft, [riot-tag="rg-toast"] .toasts.topleft{ top: 0; left: 0; } rg-toast .toasts.topright, [riot-tag="rg-toast"] .toasts.topright{ top: 0; right: 0; } rg-toast .toasts.bottomleft, [riot-tag="rg-toast"] .toasts.bottomleft{ bottom: 0; left: 0; } rg-toast .toasts.bottomright, [riot-tag="rg-toast"] .toasts.bottomright{ bottom: 0; right: 0; } rg-toast .toast, [riot-tag="rg-toast"] .toast{ padding: 20px; margin: 20px; background-color: rgba(0, 0, 0, 0.8); color: white; font-size: 13px; cursor: pointer; }',function(opts){var _this=this;if(!opts.position)opts.position="topright";this.toastClicked=function(e){if(e.item.onclick)e.item.onclick(e);if(e.item.onclose)e.item.onclose();window.clearTimeout(e.item.timer);opts.toasts.splice(opts.toasts.indexOf(e.item),1)};this.on("update",function(){opts.toasts.forEach(function(toast){toast.id=Math.random().toString(36).substr(2,8);if(!toast.timer&&!toast.sticky){toast.startTimer=function(){toast.timer=window.setTimeout(function(){opts.toasts.splice(opts.toasts.indexOf(toast),1);if(toast.onclose)toast.onclose();_this.update()},toast.timeout||6e3)};toast.startTimer()}})})});riot.tag("rg-toggle",'<div class="wrapper"> <label class="toggle"> <input type="checkbox" __checked="{ opts.toggle.checked }" onclick="{ toggle }"> <div class="track"> <div class="handle"></div> </div> </label> </div>','rg-toggle .wrapper, [riot-tag="rg-toggle"] .wrapper{ width: 60px; height: 20px; margin: 0 auto; display: block; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } rg-toggle .toggle, [riot-tag="rg-toggle"] .toggle{ position: absolute; cursor: pointer; } rg-toggle input[type=checkbox], [riot-tag="rg-toggle"] input[type=checkbox]{ display: none; } rg-toggle .track, [riot-tag="rg-toggle"] .track{ position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 60px; height: 20px; padding: 2px; background-color: #b6c0c7; -webkit-transition: background-color 0.1s linear; transition: background-color 0.1s linear; box-sizing: border-box; } rg-toggle input[type=checkbox]:checked + .track, [riot-tag="rg-toggle"] input[type=checkbox]:checked + .track{ background-color: #2db2c8; } rg-toggle .handle, [riot-tag="rg-toggle"] .handle{ position: relative; left: 0; width: 50%; height: 100%; background-color: white; -webkit-transition: transform 0.1s linear; transition: transform 0.1s linear; } rg-toggle input[type=checkbox]:checked + .track .handle, [riot-tag="rg-toggle"] input[type=checkbox]:checked + .track .handle{ -webkit-transform: translate3d(100%, 0, 0); transform: translate3d(100%, 0, 0); }',function(opts){opts.toggle=opts.toggle?opts.toggle:{};this.toggle=function(e){opts.toggle.checked=!opts.toggle.checked;if(opts.toggle.ontoggle)opts.toggle.ontoggle(e)}});riot.tag("rg-unsplash",'<img riot-src="https://unsplash.it/{ grayscale }{ width }/{ height }/?{ options }">',function(opts){this.width=opts.width||450;this.height=opts.height||250;this.options="";if(opts.greyscale||opts.grayscale)this.grayscale="g/";if(opts.random)this.options+="random&";if(opts.blur)this.options+="blur&";if(opts.image)this.options+="image="+opts.image+"&";if(opts.gravity)this.options+="gravity="+opts.gravity}); | ||
riot.tag("rg-placeholdit",'<img riot-src="https://placeholdit.imgix.net/~text?bg={ background }&txtclr={ color }&txt={ text }&txtsize={ textSize }&w={ width }&h={ height }&fm={ format }">',function(opts){this.width=opts.width||450;this.height=opts.height||250;this.background=opts["background-color"]||"f01e52";this.color=opts.color||"fff";this.text=opts.text||this.width+" x "+this.height;this.textSize=opts["font-size"]||"30";this.format=opts.format||"png"});"use strict";(function(){var _states=[];var findStateByName=function findStateByName(name){return _states.find(function(state){if(state.name==name)return state})};var findStateByUrl=function findStateByUrl(url){return _states.find(function(state){if(state.url==url)return state})};var handlePop=function handlePop(e){if(e.state)router.go(e.state,true)};var changeState=function changeState(state,popped){if(typeof history.pushState!="undefined"&&state.history!=false){if(!history.state||history.state.name!=state.name&&!popped){var url=state.url?"#!/"+state.url:null;history.pushState(state.name,null,url)}}var prevState=Object.assign({},router.current);router.current=state;router.trigger("go",state,prevState)};var router={add:function add(state){if(!state||!state.name){throw"Please specify a state name";return}var _state=findStateByName(state);if(_state)_state=state;else _states.push(state);router.trigger("add",_state)},remove:function remove(name){var _state=undefined;_states=_states.filter(function(state){if(state.name!=name)return state;else _state=state});router.trigger("remove",_state)},go:function go(name,popped){if(!router.active||!name)return;var _state=findStateByName(name);if(!_state){throw"State '"+name+"' has not been configured";return}var names=name.split(".");names=names.map(function(name,i){if(i>0){return names.slice(0,i).join(".")+"."+name}else{return name}});names.forEach(function(name,i){if(i<names.length){var _parent=findStateByName(name);_state=Object.assign({},_state,_parent)}});if(typeof _state.resolve=="function"){var promise=_state.resolve();if(typeof promise.then=="function")promise.then(function(){return changeState(_state,popped)})}else{changeState(_state,popped)}},start:function start(){router.active=true;if(window.location.hash){var _state=findStateByUrl(window.location.hash.replace("#!/",""));if(_state)router.go(_state.name)}window.addEventListener("popstate",handlePop);router.trigger("start")},stop:function stop(){router.active=false;window.addEventListener("popstate",handlePop);router.trigger("stop")},current:undefined,active:false};riot.observable(router);riot.mixin("rg.router",{init:function init(){this.router.on("go",this.update)},router:router});if(!window.rg)window.rg={};window.rg.router=router})();riot.tag("rg-select",'<div class="container { open: opened }" riot-style="width: { width }"> <input type="text" class="field { open: opened}" onkeydown="{ handleKeys }" onclick="{ toggle }" value="{ fieldText || opts.placeholder }" readonly> <div class="dropdown" show="{ opened }"> <div class="filter"> <input type="text" name="filter" class="filter-box" placeholder="{ opts[\'filter-placeholder\'] || \'Filter\' }" onkeydown="{ handleKeys }" oninput="{ filterItems }"> </div> <div class="list"> <ul> <li each="{ filteredItems }" onclick="{ parent.select }" class="item { selected: selected, disabled: disabled, active: active }"> { text } </li> </ul> </div> </div> </div>','rg-select .container, [riot-tag="rg-select"] .container{ position: relative; display: inline-block; cursor: pointer; } rg-select .container.open, [riot-tag="rg-select"] .container.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-select .field, [riot-tag="rg-select"] .field{ width: 100%; padding: 10px; background-color: white; border: 1px solid #D3D3D3; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 1em; line-height: normal; outline: 0; } rg-select .down-arrow, [riot-tag="rg-select"] .down-arrow{ float: right; } rg-select .dropdown, [riot-tag="rg-select"] .dropdown{ position: relative; width: 100%; background-color: white; border: 1px solid #D3D3D3; border-top: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } rg-select .container.open .dropdown, [riot-tag="rg-select"] .container.open .dropdown{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-select .filter-box, [riot-tag="rg-select"] .filter-box{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 100%; padding: 10px; font-size: 0.9rem; border: 0; outline: none; color: #555; } rg-select ul, [riot-tag="rg-select"] ul,rg-select li, [riot-tag="rg-select"] li{ list-style: none; padding: 0; margin: 0; } rg-select li, [riot-tag="rg-select"] li{ padding: 10px; border-top: 1px solid #E8E8E8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-select .selected, [riot-tag="rg-select"] .selected{ font-weight: bold; background-color: #f8f8f8; } rg-select li:hover, [riot-tag="rg-select"] li:hover{ background-color: #f3f3f3; } rg-select li.active, [riot-tag="rg-select"] li.active,rg-select li:hover.active, [riot-tag="rg-select"] li:hover.active{ background-color: #ededed; }',function(opts){var _this=this;this.opened=true;var handleClickOutside=function handleClickOutside(e){if(!_this.root.contains(e.target)){if(opts.onclose&&_this.opened)opts.onclose();_this.opened=false;_this.update()}};this.handleKeys=function(e){if(e.keyCode==13&&!_this.opened){_this.toggle();return true}var length=_this.filteredItems.length;if(length>0&&[13,38,40].indexOf(e.keyCode)>-1){e.preventDefault();var activeIndex=null;for(var i=0;i<length;i++){var item=_this.filteredItems[i];if(item.active){activeIndex=i;break}}if(activeIndex!=null)_this.filteredItems[activeIndex].active=false;if(e.keyCode==38){if(activeIndex==null||activeIndex==0)_this.filteredItems[length-1].active=true;else _this.filteredItems[activeIndex-1].active=true}else if(e.keyCode==40){if(activeIndex==null||activeIndex==length-1)_this.filteredItems[0].active=true;else _this.filteredItems[activeIndex+1].active=true}else if(e.keyCode==13&&activeIndex!=null){_this.select({item:_this.filteredItems[activeIndex]})}}return true};this.toggle=function(){_this.opened=!_this.opened;if(opts.onopen&&_this.opened)opts.onopen();else if(opts.onclose&&!_this.opened)opts.onclose()};this.filterItems=function(){_this.filteredItems=opts.options.filter(function(item){item.active=false;var filterField=item[opts["filter-on"]||"text"];if(_this.filter.value.length==0||filterField.toString().toLowerCase().indexOf(_this.filter.value.toString().toLowerCase())>-1)return true});if(opts.onfilter)opts.onfilter();_this.update()};this.select=function(item){item=item.item;opts.options.forEach(function(item){return item.selected=false});item.selected=true;if(opts.onselect)opts.onselect(item);_this.fieldText=item.text;_this.opened=false};this.on("mount",function(){_this.filterItems();opts.options.forEach(function(item,i){item.index=i;if(item.selected)_this.select({item:item})});document.addEventListener("click",handleClickOutside);var dd=_this.root.querySelector(".dropdown");_this.width=dd.getBoundingClientRect().width+20+"px";dd.style.position="absolute";_this.opened=opts.opened;_this.update()});this.on("unmount",function(){return document.removeEventListener("click",handleClickOutside)})});riot.tag("rg-sidemenu",'<div class="overlay { expanded: opts.sidemenu.expanded }" onclick="{ close }"></div> <div class="sidemenu { expanded: opts.sidemenu.expanded }"> <h4 class="header">{ opts.sidemenu.header }</h4> <ul class="items"> <li class="item { active: active }" each="{ opts.sidemenu.items }" onclick="{ selected }"> { text } </li> </ul> <div class="body"> <yield></yield> </div> </div>','rg-sidemenu .overlay, [riot-tag="rg-sidemenu"] .overlay{ position: fixed; top: 0; left: -100%; right: 0; bottom: 0; width: 100%; height: 100%; background-color: transparent; cursor: pointer; -webkit-transition: background-color 0.8s ease, left 0s 0.8s; -moz-transition: background-color 0.8s ease, left 0s 0.8s; -ms-transition: background-color 0.8s ease, left 0s 0.8s; -o-transition: background-color 0.8s ease, left 0s 0.8s; transition: background-color 0.8s ease, left 0s 0.8s; z-index: 50; } rg-sidemenu .overlay.expanded, [riot-tag="rg-sidemenu"] .overlay.expanded{ left: 0; background-color: rgba(0, 0, 0, 0.8); -webkit-transition: background-color 0.8s ease, left 0s; -moz-transition: background-color 0.8s ease, left 0s; -ms-transition: background-color 0.8s ease, left 0s; -o-transition: background-color 0.8s ease, left 0s; transition: background-color 0.8s ease, left 0s; } rg-sidemenu .sidemenu, [riot-tag="rg-sidemenu"] .sidemenu{ position: fixed; top: 0; left: 0; height: 100%; width: 260px; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; background-color: black; color: white; -webkit-transform: translate3d(-100%, 0, 0); -moz-transform: translate3d(-100%, 0, 0); -ms-transform: translate3d(-100%, 0, 0); -o-transform: translate3d(-100%, 0, 0); transform: translate3d(-100%, 0, 0); -webkit-transition: -webkit-transform 0.5s ease; -moz-transition: -moz-transform 0.5s ease; -ms-transition: -ms-transform 0.5s ease; -o-transition: -o-transform 0.5s ease; transition: transform 0.5s ease; z-index: 51; } rg-sidemenu .sidemenu.expanded, [riot-tag="rg-sidemenu"] .sidemenu.expanded{ -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); -o-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } rg-sidemenu .header, [riot-tag="rg-sidemenu"] .header{ padding: 1.2rem; margin: 0; text-align: center; color: white; } rg-sidemenu .items, [riot-tag="rg-sidemenu"] .items{ padding: 0; margin: 0; list-style: none; } rg-sidemenu .item, [riot-tag="rg-sidemenu"] .item{ padding: 1rem 0.5rem; box-sizing: border-box; border-top: 1px solid #1a1a1a; color: white; } rg-sidemenu .item:last-child, [riot-tag="rg-sidemenu"] .item:last-child{ border-bottom: 1px solid #1a1a1a; } rg-sidemenu .item:hover, [riot-tag="rg-sidemenu"] .item:hover{ cursor: pointer; background-color: #2a2a2a; } rg-sidemenu .item.active, [riot-tag="rg-sidemenu"] .item.active{ cursor: pointer; background-color: #444; }',function(opts){this.close=function(){return opts.sidemenu.expanded=false};this.selected=function(item){item=item.item;opts.sidemenu.items.forEach(function(item){return item.active=false});item.active=true;if(item.action)item.action(item)}});riot.tag("rg-tag-heading-raw","<span></span>",function(opts){var _this=this;this.on("mount",function(){return _this.root.innerHTML=opts.content})});riot.tag("rg-tab-heading","<yield></yield>",'rg-tab-heading , [riot-tag="rg-tab-heading"] { display: none; }',function(opts){});riot.tag("rg-tab",'<div show="{ active }" class="tab"> <yield></yield> </div>',".tab { padding: 10px; }",function(opts){this.active=opts.active;this.disabled=opts.disabled});riot.tag("rg-tabs",'<div class="tabs"> <div class="headers"> <div each="{ tab in tabs }" class="header { active: tab.active, disabled: tab.disabled }" onclick="{ activate }"> <h4 class="heading" if="{ tab.opts.heading && !tab.heading }">{ tab.opts.heading }</h4> <div class="heading" if="{ tab.heading }"> <rg-tag-heading-raw content="{ tab.heading }"></rg-tag-heading-raw> </div> </div> </div> <yield></yield> </div>','rg-tabs .tabs, [riot-tag="rg-tabs"] .tabs{ background-color: white; } rg-tabs .headers, [riot-tag="rg-tabs"] .headers{ display: -webkit-flex; display: -ms-flexbox; display: flex; } rg-tabs .header, [riot-tag="rg-tabs"] .header{ -webkit-flex: 1; -ms-flex: 1; flex: 1; box-sizing: border-box; text-align: center; cursor: pointer; box-shadow: 0 -1px 0 0 #404040 inset; } rg-tabs .heading, [riot-tag="rg-tabs"] .heading{ padding: 10px; margin: 0; } rg-tabs .header.active, [riot-tag="rg-tabs"] .header.active{ background-color: #404040; } rg-tabs .header.active .heading, [riot-tag="rg-tabs"] .header.active .heading{ color: white; } rg-tabs .header.disabled .heading, [riot-tag="rg-tabs"] .header.disabled .heading{ color: #888; }',function(opts){var _this=this;this.onopen=opts.onopen;this.tabs=this.tags["rg-tab"];var deselectTabs=function deselectTabs(){return _this.tabs.forEach(function(tab){return tab.active=false})};this.on("mount",function(){var activeTab=false;_this.tabs.forEach(function(tab,i){tab.index=i;var tabHeading=tab.tags["rg-tab-heading"];if(tabHeading){if(Object.prototype.toString.call(tabHeading)!=="[object Array]")tab.heading=tabHeading.root.innerHTML}if(activeTab)tab.active=false;if(tab.active)activeTab=true});_this.update()});this.activate=function(e){tab=e.item.tab;if(!tab.disabled){deselectTabs();if(_this.onopen)_this.onopen(tab);tab.active=true}}});riot.tag("rg-tags",'<div class="container"> <span class="tags"> <span class="tag" each="{ opts.tags }" onclick="{ parent.removeTag }"> { text } <span class="close">×</span> </span> </span> <div class="input-container { open: opened }"> <input type="{ opts.type || \'text\' }" name="textbox" placeholder="{ opts.placeholder }" onkeydown="{ handleKeys }" oninput="{ filterItems }" onfocus="{ filterItems }"> <div class="dropdown { open: opened }" show="{ opened }"> <div class="list"> <ul> <li each="{ filteredItems }" onclick="{ parent.select }" class="item { active: active }"> { text } </li> </ul> </div> </div> </div> </div>','rg-tags .container, [riot-tag="rg-tags"] .container{ width: 100%; border: 1px solid #D3D3D3; background: white; text-align: left; padding: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } rg-tags .input-container, [riot-tag="rg-tags"] .input-container{ position: absolute; display: inline-block; cursor: pointer; } rg-tags input, [riot-tag="rg-tags"] input{ width: 100%; font-size: 1em; padding: 10px; border: 0; background-color: transparent; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; outline: none; } rg-tags .dropdown, [riot-tag="rg-tags"] .dropdown{ position: absolute; width: 100%; background-color: white; border: 1px solid #D3D3D3; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; overflow-y: auto; overflow-x: hidden; } rg-tags .dropdown.open, [riot-tag="rg-tags"] .dropdown.open{ -webkit-box-shadow: 0 2px 10px -4px #444; -moz-box-shadow: 0 2px 10px -4px #444; box-shadow: 0 2px 10px -4px #444; } rg-tags ul, [riot-tag="rg-tags"] ul,rg-tags li, [riot-tag="rg-tags"] li{ list-style: none; padding: 0; margin: 0; } rg-tags li, [riot-tag="rg-tags"] li{ padding: 10px; border-top: 1px solid #E8E8E8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } rg-tags li:first-child, [riot-tag="rg-tags"] li:first-child{ border-top: 0; } rg-tags li:hover, [riot-tag="rg-tags"] li:hover{ background-color: #f3f3f3; } rg-tags li.active, [riot-tag="rg-tags"] li.active,rg-tags li:hover.active, [riot-tag="rg-tags"] li:hover.active{ background-color: #ededed; } rg-tags .tags, [riot-tag="rg-tags"] .tags{ display: inline-block; max-width: 70%; white-space: nowrap; overflow-y: hidden; overflow-x: auto; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } rg-tags .tag, [riot-tag="rg-tags"] .tag{ position: relative; display: inline-block; padding: 5px 20px 5px 5px; margin: 4px 5px; background-color: #444; color: #fff; cursor: pointer; } rg-tags .tag:hover, [riot-tag="rg-tags"] .tag:hover,rg-tags .tag:active, [riot-tag="rg-tags"] .tag:active{ background-color: #666; } rg-tags .close, [riot-tag="rg-tags"] .close{ position: absolute; right: 5px; top: 5px; color: rgba(255,255,255,0.7); }',function(opts){var _this=this;this.opened=true;this.textbox.value=opts.value||"";opts.items=opts.items||[];opts.tags=opts.tags||[];opts.tags.forEach(function(tag,i){return tag.index=i});this.filterItems=function(){_this.filteredItems=opts.items.filter(function(item){item.active=false;if(_this.textbox.value.length==0||item.text.toString().toLowerCase().indexOf(_this.textbox.value.toString().toLowerCase())>-1)return true});_this.opened=_this.filteredItems.length>0;if(opts.onfilter)opts.onfilter();_this.update()};this.handleKeys=function(e){var length=_this.filteredItems.length;if(length>0&&[13,38,40].indexOf(e.keyCode)>-1){_this.opened=true;e.preventDefault();var activeIndex=null;for(var i=0;i<length;i++){var item=_this.filteredItems[i];if(item.active){activeIndex=i;break}}if(activeIndex!=null)_this.filteredItems[activeIndex].active=false;if(e.keyCode==38){if(activeIndex==null||activeIndex==0)_this.filteredItems[length-1].active=true;else _this.filteredItems[activeIndex-1].active=true}else if(e.keyCode==40){if(activeIndex==null||activeIndex==length-1)_this.filteredItems[0].active=true;else _this.filteredItems[activeIndex+1].active=true}else if(e.keyCode==13&&activeIndex!=null){_this.select({item:_this.filteredItems[activeIndex]})}}if(e.keyCode==13){_this.addTag()}else if(e.keyCode==8&&_this.textbox.value==""&&opts.tags.length>0){var tag=opts.tags.pop();_this.textbox.value=tag.text}return true};this.addTag=function(item){var tag=item||{text:_this.textbox.value};if(tag.text.length>0){tag.index=opts.tags.length;opts.tags.push(tag);_this.textbox.value="";_this.filteredItems=opts.items;_this.opened=false}_this.update()};this.removeTag=function(e){opts.tags.splice(opts.tags.indexOf(e.item),1);_this.opened=false};this.select=function(item){item=item.item;if(opts.onselect)opts.onselect(item);_this.addTag(item)};this.closeDropdown=function(e){if(!_this.root.contains(e.target)){if(opts.onclose&&_this.opened)opts.onclose();_this.opened=false;_this.update()}};this.on("mount",function(){document.addEventListener("click",_this.closeDropdown);document.addEventListener("focus",_this.closeDropdown,true);_this.opened=opts.opened;_this.update()});this.on("unmount",function(){document.removeEventListener("click",_this.closeDropdown);document.removeEventListener("focus",_this.closeDropdown,true)});this.on("update",function(){var containerWidth=_this.root.querySelector(".container").getBoundingClientRect().width;var tagList=_this.root.querySelector(".tags");var tagListWidth=tagList.getBoundingClientRect().width;tagList.scrollLeft=Number.MAX_VALUE;var inputContainer=_this.root.querySelector(".input-container");inputContainer.style.width=containerWidth-tagListWidth+"px";_this.root.querySelector(".container").style.height=inputContainer.getBoundingClientRect().height+"px"})});riot.tag("rg-timepicker",'<rg-select placeholder="Select a time" filter-placeholder="Filter times" options="{ times }" onopen="{ opts.onopen }" onclose="{ opts.onclose }" onselect="{ opts.onselect }"> </rg-select>',function(opts){opts.time=opts.time||"now";if(opts.time=="now")opts.time=new Date;if(opts.min)opts.min=opts.min.split(":");if(opts.max)opts.max=opts.max.split(":");var step=parseInt(opts.step)||1;this.times=[];for(var i=0;i<1440;i++){if(i%step==0){var d=new Date(0);d.setHours(opts.time.getHours());d.setMinutes(opts.time.getMinutes());d=new Date(d.getTime()+i*6e4);if(opts.min){if(d.getHours()<opts.min[0])continue;if(d.getHours()==opts.min[0]&&d.getMinutes()<opts.min[1])continue}if(opts.max){if(d.getHours()>opts.max[0])continue;if(d.getHours()==opts.max[0]&&d.getMinutes()>opts.max[1])continue}var t={hours:d.getHours(),minutes:d.getMinutes()};var m=t.minutes;if(m<10)m="0"+m;if(opts.ampm){var ampm="am";var h=t.hours;if(h>=12){ampm="pm";h=h-12}if(h==0)h=12;t.text=h+":"+m+" "+ampm;t.period=ampm}else{var h=t.hours;if(h<10)h="0"+h;t.text=h+":"+m}this.times.push(t)}}});riot.tag("rg-toast",'<div class="toasts { opts.position }" if="{ opts.toasts.length > 0 }"> <div class="toast" each="{ opts.toasts }" onclick="{ parent.toastClicked }"> { text } </div> </div>','rg-toast .toasts, [riot-tag="rg-toast"] .toasts{ position: fixed; width: 250px; max-height: 100%; overflow-y: auto; background-color: transparent; z-index: 101; } rg-toast .toasts.topleft, [riot-tag="rg-toast"] .toasts.topleft{ top: 0; left: 0; } rg-toast .toasts.topright, [riot-tag="rg-toast"] .toasts.topright{ top: 0; right: 0; } rg-toast .toasts.bottomleft, [riot-tag="rg-toast"] .toasts.bottomleft{ bottom: 0; left: 0; } rg-toast .toasts.bottomright, [riot-tag="rg-toast"] .toasts.bottomright{ bottom: 0; right: 0; } rg-toast .toast, [riot-tag="rg-toast"] .toast{ padding: 20px; margin: 20px; background-color: rgba(0, 0, 0, 0.8); color: white; font-size: 13px; cursor: pointer; }',function(opts){var _this=this;if(!opts.position)opts.position="topright";this.toastClicked=function(e){if(e.item.onclick)e.item.onclick(e);if(e.item.onclose)e.item.onclose();window.clearTimeout(e.item.timer);opts.toasts.splice(opts.toasts.indexOf(e.item),1)};this.on("update",function(){opts.toasts.forEach(function(toast){toast.id=Math.random().toString(36).substr(2,8);if(!toast.timer&&!toast.sticky){toast.startTimer=function(){toast.timer=window.setTimeout(function(){opts.toasts.splice(opts.toasts.indexOf(toast),1);if(toast.onclose)toast.onclose();_this.update()},toast.timeout||6e3)};toast.startTimer()}})})});riot.tag("rg-toggle",'<div class="wrapper"> <label class="toggle"> <input type="checkbox" __checked="{ opts.toggle.checked }" onclick="{ toggle }"> <div class="track"> <div class="handle"></div> </div> </label> </div>','rg-toggle .wrapper, [riot-tag="rg-toggle"] .wrapper{ width: 60px; height: 20px; margin: 0 auto; display: block; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } rg-toggle .toggle, [riot-tag="rg-toggle"] .toggle{ position: absolute; cursor: pointer; } rg-toggle input[type=checkbox], [riot-tag="rg-toggle"] input[type=checkbox]{ display: none; } rg-toggle .track, [riot-tag="rg-toggle"] .track{ position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 60px; height: 20px; padding: 2px; background-color: #b6c0c7; -webkit-transition: background-color 0.1s linear; transition: background-color 0.1s linear; box-sizing: border-box; } rg-toggle input[type=checkbox]:checked + .track, [riot-tag="rg-toggle"] input[type=checkbox]:checked + .track{ background-color: #2db2c8; } rg-toggle .handle, [riot-tag="rg-toggle"] .handle{ position: relative; left: 0; width: 50%; height: 100%; background-color: white; -webkit-transition: transform 0.1s linear; transition: transform 0.1s linear; } rg-toggle input[type=checkbox]:checked + .track .handle, [riot-tag="rg-toggle"] input[type=checkbox]:checked + .track .handle{ -webkit-transform: translate3d(100%, 0, 0); transform: translate3d(100%, 0, 0); }',function(opts){opts.toggle=opts.toggle?opts.toggle:{};this.toggle=function(e){opts.toggle.checked=!opts.toggle.checked;if(opts.toggle.ontoggle)opts.toggle.ontoggle(e)}});riot.tag("rg-unsplash",'<img riot-src="https://unsplash.it/{ grayscale }{ width }/{ height }/?{ options }">',function(opts){this.width=opts.width||450;this.height=opts.height||250;this.options="";if(opts.greyscale||opts.grayscale)this.grayscale="g/";if(opts.random)this.options+="random&";if(opts.blur)this.options+="blur&";if(opts.image)this.options+="image="+opts.image+"&";if(opts.gravity)this.options+="gravity="+opts.gravity}); |
{ | ||
"name": "riotgear", | ||
"version": "1.15.2", | ||
"version": "1.15.3", | ||
"description": "The open source component library for RiotJS", | ||
@@ -5,0 +5,0 @@ "main": "dist/rg.min.js", |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package