UNPKG

foam-framework

Version:
141 lines (135 loc) 6.06 kB
/** * @license * Copyright 2015 Google Inc. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 */ CLASS({ package: 'foam.apps.builder', name: 'StateView', extends: 'foam.ui.SimpleView', constants: { STATES: { AUTHENTICATING: { icon: '', label: 'Authenticating', }, UPLOADING: { icon: '', label: 'Uploading', }, PUBLISHING: { icon: '', label: 'Publishing', }, DOWNLOADING: { icon: '', label: 'Downloading', }, IMPORTING: { icon: '', label: 'Importing', }, COMPLETED: { icon: '', label: 'Completed', }, FAILED: { icon: '', label: 'Failed', }, }, }, properties: [ { name: 'data', postSet: function(old, nu) { this.onDataStateChange(); }, }, { model_: 'StringProperty', name: 'className', defaultValue: 'md-subhead', }, { model_: 'StringProperty', name: 'stateLabelClassName', defaultValue: 'md-grey', }, { name: '$icon', defaultValueFn: function() { return this.$ && this.$.querySelector('img'); } }, { name: '$label', defaultValueFn: function() { return this.$ && this.$.querySelector('state-label'); } }, ], listeners: [ { name: 'onDataStateChange', code: function() { if ( ! this.$ ) return; var state = this.STATES[this.data]; if ( ! state ) return; this.$icon.src = state.icon; this.$label.textContent = state.label; }, }, ], templates: [ function toHTML() {/* <flow-state id="%%id" %%cssClassAttr()><% this.toInnerHTML(out); %></flow-state> */}, function toInnerHTML() {/* <% var state = this.STATES[this.data]; if ( state ) { %> <img id="%%id-icon" src="{{state.icon}}"> <state-label class="{{this.stateLabelClassName}}">{{state.label}}</state-label> <% } this.setClass('processing', function() { return this.data !== 'FAILED' && this.data !== 'COMPLETED'; }.bind(this), this.id + '-icon'); %> */}, function CSS() {/* @keyframes pulseopacity { 0% { opacity: 1; } 100% { opacity: 0.3; } } flow-state { display: flex; } flow-state { align-items: center; justify-content: center; } flow-state img { flex-grow: 0; flex-shrink: 0; } flow-state img.processing { animation-name: pulseopacity; animation-duration: 0.8s; animation-timing-function: cubic-bezier(0,.3,.8,1); animation-delay: 0; animation-direction: alternate; animation-iteration-count: infinite; animation-fill-mode: none; animation-play-state: running; } flow-state img, flow-state state-label { margin: 0; } flow-state state-label { margin-left: 12px; } */}, ], });