foam-framework
Version:
MVC metaprogramming framework
451 lines (437 loc) • 17.4 kB
JavaScript
/**
* @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: 'ExportConfirmView',
extends: 'foam.ui.SimpleView',
requires: [
'foam.apps.builder.InfoOptionView',
'foam.ui.Icon',
'foam.ui.md.CheckboxView',
'foam.ui.md.FlatButton',
],
imports: [
'popup',
'appBuilderAnalyticsEnabled$ as appBuilderAnalyticsInitialValue_$',
],
properties: [
{
type: 'foam.apps.builder.AppConfig',
name: 'data',
postSet: function(old, nu) {
if ( old ) {
old.appBuilderAnalyticsEnabled$.removeListener(this.onABAnalyticsChange);
old.analyticsId$.removeListener(this.onAnalyticsIdChange);
old.userDataWarning$.removeListener(this.onUserDataWarningChange);
}
if ( nu ) {
nu.appBuilderAnalyticsEnabled = this.appBuilderAnalyticsInitialValue_;
nu.appBuilderAnalyticsEnabled$.addListener(this.onABAnalyticsChange);
nu.analyticsId$.addListener(this.onAnalyticsIdChange);
nu.userDataWarning$.addListener(this.onUserDataWarningChange);
}
},
},
{
model_: 'StringProperty',
name: 'title',
defaultValue: 'App Export',
},
{
model_: 'StringProperty',
name: 'actionName',
defaultValue: 'exportApp',
},
{
model_: 'BooleanProperty',
name: 'mayPublishToCWS',
label: 'This app will be deployed to the Chrome Web Store',
defaultValue: true,
},
{
model_: 'ViewFactoryProperty',
name: 'infoIcon',
defaultValue: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'info',
color: '#02A8F3',
},
},
{
model_: 'ViewFactoryProperty',
name: 'warningIcon',
defaultValue: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'warning',
color: '#02A8F3',
},
},
{
model_: 'ViewFactoryProperty',
name: 'permissions',
defaultValue: function() {
var permissionsText = this.prettyPermissionsHTML();
return this.InfoOptionView.create({
icon: this.infoIcon,
title: 'Your app permissions',
details: function() {
return '<pre class="md-quote info-content">' +
permissionsText + '</pre>';;
},
});
},
},
'permissionsView',
{
model_: 'ViewFactoryProperty',
name: 'analyticsThanks',
defaultValue: function() {
return this.InfoOptionView.create({
icon: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'mood',
color: '#02A8F3',
},
title: 'Thanks for supporting App Builder!',
details: function() {
return multiline(function() {/*
<div class="md-body">
By sending analytics data to the App Builder team you help us
better understand how the world is benefiting App Builder. This
helps us focus on the features that you need most.<br>
<a href="#">Learn more</a>
</div>
*/});
},
});
},
},
'analyticsThanksView',
{
model_: 'ViewFactoryProperty',
name: 'analyticsNoThanks',
defaultValue: function() {
return this.InfoOptionView.create({
icon: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'mood_bad',
color: '#02A8F3',
},
title: "The App Builder team can't support apps we don't know about!",
details: function() {
return multiline(function() {/*
<div class="md-body">
When you opt-out of sending analytics data to the App Builder
team, it makes your app invisible to us. Rest assured, our
analytics data collection contains no personal information about
you or your users. Just things like how many people use your app
and how often.<br>
<a href="#">Learn more</a>
</div>
*/});
},
});
},
},
'analyticsNoThanksView',
{
model_: 'ViewFactoryProperty',
name: 'ownAnalytics',
defaultValue: function() {
return this.InfoOptionView.create({
icon: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'warning',
color: '#02A8F3',
},
title: 'Your analytics data collection may require user consent',
details: function() {
return multiline(function() {/*
<div class="md-body">
This application is configured to use analytics data. If you
intend to deploy it on the Chrome Web Store you <b>must</b>
obtain consent from users to collect these data by linking to a
Privacy Policy from your Chome Web Store app entry.<br>
<a href="#">Learn more</a>
</div>
*/});
},
});
},
},
'ownAnalyticsView',
{
model_: 'ViewFactoryProperty',
name: 'abAnalytics',
defaultValue: function() {
return this.InfoOptionView.create({
icon: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'warning',
color: '#02A8F3',
},
title: 'App Builder analytics data collection may require user consent',
details: function() {
return multiline(function() {/*
<div class="md-body">
This application is configured to send analytics data to the App
Builder team. If you intend to deploy it on the Chrome Web Store
you <b>must</b> obtain consent from users to collect these data
by linking to a Privacy Policy from your Chome Web Store app
entry.<br>
<a href="#">Learn more</a>
</div>
*/});
},
});
},
},
'abAnalyticsView',
{
model_: 'ViewFactoryProperty',
name: 'userDataWarning',
defaultValue: function() {
return this.InfoOptionView.create({
icon: {
factory_: 'foam.ui.Icon',
url: '',
ligature: 'warning',
color: '#02A8F3',
},
title: 'User data collection may require user consent',
details: this.data.userDataWarning || function() { return ''; },
});
},
},
'userDataWarningView',
{
name: 'result',
lazyFactory: function() {
return this.result_.get;
},
},
{
name: 'result_',
lazyFactory: function() {
return afuture();
},
},
{
model_: 'BooleanProperty',
name: 'appBuilderAnalyticsInitialValue_',
defaultValue: true,
postSet: function() {
if ( this.data )
this.data.appBuilderAnalyticsEnabled =
this.appBuilderAnalyticsInitialValue_;
},
},
],
methods: [
function init() {
this.SUPER();
this.mayPublishToCWS$.addListener(this.onMayPublishChange);
},
// TODO(markdittmer): This should be pushed to a more general view model.
function addFactoryChild(fName) {
var view = this[fName]();
this[fName + 'View'] = view;
this.addChild(view);
return view;
},
],
actions: [
{
model_: 'foam.metrics.TrackedAction',
name: 'confirm',
label: 'Confirm',
trackingNameFn: function(X, self) {
return this.name + ':' + self.actionName;
},
iconUrl: '',
ligature: 'done',
code: function() {
this.popup && this.popup.close();
this.result_.set(true);
},
},
{
model_: 'foam.metrics.TrackedAction',
name: 'cancel',
label: 'Cancel',
trackingNameFn: function(X, self) {
return this.name + ':' + self.actionName;
},
iconUrl: '',
ligature: 'close',
code: function() {
this.popup && this.popup.close();
this.result_.set(false);
},
}
],
listeners: [
{
name: 'onAnalyticsIdChange',
code: function() {
if ( ( ! this.data ) || ( ! this.ownAnalyticsView ) ) return;
this.ownAnalyticsView[this.data.analyticsId ?
'expand' : 'collapse']();
},
},
{
name: 'onABAnalyticsChange',
code: function() {
if ( ( ! this.data ) ) return;
if ( this.analyticsThanksView )
this.analyticsThanksView[this.data.appBuilderAnalyticsEnabled ?
'expand' : 'collapse']();
if ( this.analyticsNoThanksView )
this.analyticsNoThanksView[this.data.appBuilderAnalyticsEnabled ?
'collapse' : 'expand']();
if ( this.abAnalyticsView )
this.abAnalyticsView[this.data.appBuilderAnalyticsEnabled ?
'expand' : 'collapse']();
},
},
{
name: 'onUserDataWarningChange',
code: function() {
if ( ( ! this.data ) || ( ! this.userDataWarningView ) ) return;
this.userDataWarningView[this.data.userDataWarning ?
'expand' : 'collapse']();
},
},
],
templates: [
function toHTML() {/*
<export-confirm id="%%id">
<div class="md-card-heading">
<span class="md-headline">{{this.title}}</span>
</div>
<div class="md-card-heading-content-spacer"></div>
<div class="main-confirm-content">
<%= this.addFactoryChild('permissions') %>
<% this.permissionsView.expand(); %>
<div class="md-card-content">
$$appBuilderAnalyticsEnabled{
model_: 'foam.ui.md.CheckboxView',
extraClassName: 'option',
}
</div>
<%= this.addFactoryChild('analyticsThanks') %>
<%= this.addFactoryChild('analyticsNoThanks') %>
<%= this.addFactoryChild('ownAnalytics') %>
<% this.onAnalyticsIdChange(); %>
<%= this.addFactoryChild('abAnalytics') %>
<% this.onABAnalyticsChange(); %>
<%= this.addFactoryChild('userDataWarning') %>
<% this.onUserDataWarningChange(); %>
</div>
<div class="md-card-content-footer-spacer"></div>
<actions class="md-actions md-card-footer horizontal">
$$cancel{ model_: 'foam.ui.md.FlatButton', displayMode: 'LABEL_ONLY' }
$$confirm{ model_: 'foam.ui.md.FlatButton', displayMode: 'LABEL_ONLY' }
</actions>
</export-confirm>
*/},
function prettyPermissionsHTML() {/*<%
var permissions = this.data ? this.data.getChromePermissions() : '';
if ( permissions ) {
for ( var i = 0; i < permissions.length; ++i ) {
if ( typeof permissions[i] === 'string' ) {
%><%= permissions[i] %>
<% continue;
} %>[
<% for ( var key in permissions[i] ) {
if ( permissions[i].hasOwnProperty(key) ) {
%> <%= key %>: <%= permissions[i][key] %>,
<% }
} %>]
<% }
} else { %>No permissions<% } %>*/},
function warningsHTML() {/*
<%= this.addFactoryChild('ownAnalytics') %>
<% this.onAnalyticsIdChange(); %>
<%= this.addFactoryChild('abAnalytics') %>
<% this.onABAnalyticsChange(); %>
*/},
function CSS() {/*
export-confirm {
display: block;
max-width: 800px;
}
export-confirm img {
margin-right: 12px;
}
export-confirm hr {
margin-top: 8px;
margin-bottom: 8px;
}
export-confirm pre {
margin: 0;
}
export-confirm .main-confirm-content {
border-bottom: 1px solid rgba(0,0,0,0.1);
}
export-confirm .info-content {
margin-left: 52px;
margin-bottom: 8px;
}
export-confirm .option .md-grey {
font-size: 14px;
opacity: 1.0;
}
export-confirm .info {
border-top: 1px solid rgba(0,0,0,0.1);
}
export-confirm .info-heading {
margin-top: 8px;
margin-bottom: 8px;
}
export-confirm .default-hidden {
display: none;
}
export-confirm .default-hidden.show {
display: block;
}
export-confirm .rows {
display: flex;
flex-direction: row;
align-items: flex-start;
}
export-confirm .post-hr {
padding-top: 16px;
}
export-confirm .warning {
padding-top: 8px;
padding-right: 36px;
}
export-confirm .rows img {
flex-grow: 0;
}
export-confirm .rows span, export-confirm .rows div {
flex-grow: 1;
}
@media (min-width: 600px) {
export-confirm {
min-width: 570px;
}
}
*/},
],
});