diff --git a/dist/ng-helper.js b/dist/ng-helper.js index fc2afa7..fe8f286 100644 --- a/dist/ng-helper.js +++ b/dist/ng-helper.js @@ -866,7 +866,8 @@ // Allowed events from parrent iFrame this.events = { - 'component': this.loadComponent + 'component': this.loadComponent, + 'model': this.loadModel }; } @@ -888,6 +889,16 @@ value: function $onDestroy() { this.postMessageListener(); } + }, { + key: 'loadModel', + value: function loadModel(model) { + if (model) { + for (var k in model) { + this[k] = model[k]; + } + } + this.$scope.$apply(); + } }, { key: 'loadComponent', value: function loadComponent(component) { diff --git a/dist/sb.js b/dist/sb.js index 04882ba..d1a7b49 100644 --- a/dist/sb.js +++ b/dist/sb.js @@ -342,192 +342,7 @@ /* 292 */, /* 293 */, /* 294 */, -/* 295 */ -/***/ function(module, exports) { - - // shim for using process in browser - var process = module.exports = {}; - - // cached from whatever global is present so that test runners that stub it - // don't break things. But we need to wrap it in a try catch in case it is - // wrapped in strict mode code which doesn't define any globals. It's inside a - // function because try/catches deoptimize in certain engines. - - var cachedSetTimeout; - var cachedClearTimeout; - - function defaultSetTimout() { - throw new Error('setTimeout has not been defined'); - } - function defaultClearTimeout () { - throw new Error('clearTimeout has not been defined'); - } - (function () { - try { - if (typeof setTimeout === 'function') { - cachedSetTimeout = setTimeout; - } else { - cachedSetTimeout = defaultSetTimout; - } - } catch (e) { - cachedSetTimeout = defaultSetTimout; - } - try { - if (typeof clearTimeout === 'function') { - cachedClearTimeout = clearTimeout; - } else { - cachedClearTimeout = defaultClearTimeout; - } - } catch (e) { - cachedClearTimeout = defaultClearTimeout; - } - } ()) - function runTimeout(fun) { - if (cachedSetTimeout === setTimeout) { - //normal enviroments in sane situations - return setTimeout(fun, 0); - } - // if setTimeout wasn't available but was latter defined - if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { - cachedSetTimeout = setTimeout; - return setTimeout(fun, 0); - } - try { - // when when somebody has screwed with setTimeout but no I.E. maddness - return cachedSetTimeout(fun, 0); - } catch(e){ - try { - // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally - return cachedSetTimeout.call(null, fun, 0); - } catch(e){ - // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error - return cachedSetTimeout.call(this, fun, 0); - } - } - - - } - function runClearTimeout(marker) { - if (cachedClearTimeout === clearTimeout) { - //normal enviroments in sane situations - return clearTimeout(marker); - } - // if clearTimeout wasn't available but was latter defined - if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { - cachedClearTimeout = clearTimeout; - return clearTimeout(marker); - } - try { - // when when somebody has screwed with setTimeout but no I.E. maddness - return cachedClearTimeout(marker); - } catch (e){ - try { - // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally - return cachedClearTimeout.call(null, marker); - } catch (e){ - // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. - // Some versions of I.E. have different rules for clearTimeout vs setTimeout - return cachedClearTimeout.call(this, marker); - } - } - - - - } - var queue = []; - var draining = false; - var currentQueue; - var queueIndex = -1; - - function cleanUpNextTick() { - if (!draining || !currentQueue) { - return; - } - draining = false; - if (currentQueue.length) { - queue = currentQueue.concat(queue); - } else { - queueIndex = -1; - } - if (queue.length) { - drainQueue(); - } - } - - function drainQueue() { - if (draining) { - return; - } - var timeout = runTimeout(cleanUpNextTick); - draining = true; - - var len = queue.length; - while(len) { - currentQueue = queue; - queue = []; - while (++queueIndex < len) { - if (currentQueue) { - currentQueue[queueIndex].run(); - } - } - queueIndex = -1; - len = queue.length; - } - currentQueue = null; - draining = false; - runClearTimeout(timeout); - } - - process.nextTick = function (fun) { - var args = new Array(arguments.length - 1); - if (arguments.length > 1) { - for (var i = 1; i < arguments.length; i++) { - args[i - 1] = arguments[i]; - } - } - queue.push(new Item(fun, args)); - if (queue.length === 1 && !draining) { - runTimeout(drainQueue); - } - }; - - // v8 likes predictible objects - function Item(fun, array) { - this.fun = fun; - this.array = array; - } - Item.prototype.run = function () { - this.fun.apply(null, this.array); - }; - process.title = 'browser'; - process.browser = true; - process.env = {}; - process.argv = []; - process.version = ''; // empty string to avoid regexp issues - process.versions = {}; - - function noop() {} - - process.on = noop; - process.addListener = noop; - process.once = noop; - process.off = noop; - process.removeListener = noop; - process.removeAllListeners = noop; - process.emit = noop; - - process.binding = function (name) { - throw new Error('process.binding is not supported'); - }; - - process.cwd = function () { return '/' }; - process.chdir = function (dir) { - throw new Error('process.chdir is not supported'); - }; - process.umask = function() { return 0; }; - - -/***/ }, +/* 295 */, /* 296 */, /* 297 */, /* 298 */, @@ -79942,6 +79757,13 @@ this.$state = $state; this.listener = $rootScope.$on('render', function (event, component) { + + // If need to render template from function + // convert it to string to pass with postMessage to iFrame + if (typeof component.template === 'function') { + component.template = encodeURI(component.template); + } + _this.render(event, { type: 'component', data: component @@ -79994,7 +79816,11 @@ }, { key: 'render', value: function render(event, data) { - this._bridge.postMessage(data, '*'); + try { + this._bridge.postMessage(data, '*'); + } catch (e) { + console.log(e); + } } }, { key: 'initDevice', @@ -80147,7 +79973,7 @@ /* 371 */ /***/ function(module, exports) { - module.exports = "
\n\t\n\t\n\t\n\t\tarrow_back\n\t\n
\n
\n\tsearch\n\t\n
\n\n\t

Section

\n\t\n\t\t\n\t\t\t\n\t\t\n\t\n
\n
\n\t\n\t\n\t\t
\n\t\t\t

\n\t\t
\n\t
\n
" + module.exports = "
\n\n\t
\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\tarrow_back\n\t\t\n\t
\n\n\t
\n\t\tsearch\n\t\t\n\t\t\n\t\t\tclose\n\t\t\n\t
\n\n
\n\n\t

Section

\n\t\n\t\t\n\t\t\t\n\t\t\n\t\n
\n\n\t
\n\t\t\n\t\t\n\t\t\t
\n\t\t\t\t

\n\t\t\t
\n\t\t
\n\t
\n
" /***/ }, /* 372 */ @@ -80211,6 +80037,20 @@ } (0, _createClass3.default)(StoryListController, [{ + key: 'openSearch', + value: function openSearch() { + this.searchPanel = true; + setTimeout(function () { + return document.getElementsByClassName('search__input')[0].focus(); + }, 0); + } + }, { + key: 'closeSearch', + value: function closeSearch() { + this.search = ''; + this.searchPanel = false; + } + }, { key: 'selectSection', value: function selectSection(sectionTitle) { this.selectStory(sectionTitle); @@ -80245,6 +80085,8 @@ notify: false }); + this.closeSearch(); + this.$rootScope.$broadcast('render', component); } }, { @@ -80569,7 +80411,7 @@ // module - exports.push([module.id, ".sidebar__header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n border-bottom: 1px solid rgba(0, 0, 0, 0.12);\n}\n.search {\n display: flex;\n align-items: center;\n padding-left: 13px;\n}\n.search .icon__search {\n color: #444;\n opacity: 0.5;\n}\n.search .search__input {\n width: 100%;\n height: 60px;\n border: none;\n padding: 0 10px;\n outline: none;\n}\n.story__name {\n font-size: 14px;\n font-weight: 500;\n color: rgba(0, 0, 0, 0.54);\n letter-spacing: 0px;\n padding: 16px;\n background: #fff;\n}\n.story__point {\n cursor: pointer;\n color: rgba(0, 0, 0, 0.54);\n outline: none;\n height: 48px !important;\n min-height: 48px !important;\n}\n.story__point .md-button {\n padding-left: 32px !important;\n min-height: 48px !important;\n height: 48px !important;\n}\n.story__point.active {\n color: #448aff;\n}\n.story__list-item {\n font-size: 14px !important;\n}\n.button__close-sidebar {\n margin-right: 16px;\n color: rgba(0, 0, 0, 0.54);\n}\n.section__select {\n padding: 0 16px;\n}\n.section__select h2 {\n font-size: 16px;\n font-weight: 500;\n color: rgba(0, 0, 0, 0.54);\n margin: 8px 0;\n}\n.section__select md-select {\n display: inline-block;\n}\n.section__select span {\n color: rgba(0, 0, 0, 0.54);\n text-transform: capitalize;\n}\n.sb-logo {\n width: 65px;\n height: 60px;\n background-size: 40px;\n background-repeat: no-repeat;\n background-position: 50%;\n background-image: url();\n}\n", ""]); + exports.push([module.id, "story-list {\n overflow: hidden;\n display: flex;\n flex-direction: column;\n}\n.sidebar__header {\n align-items: center;\n justify-content: space-between;\n border-bottom: 1px solid rgba(0, 0, 0, 0.12);\n}\n.sidebar__header-main {\n display: flex;\n align-items: center;\n width: 100%;\n}\n.icon__search {\n color: rgba(0, 0, 0, 0.54);\n}\n.search {\n display: flex;\n align-items: center;\n padding-left: 13px;\n}\n.search .search__input {\n width: 210px;\n height: 60px;\n border: none;\n padding: 0 10px;\n outline: none;\n}\n.story__name {\n font-size: 14px;\n font-weight: 500;\n color: #448aff;\n letter-spacing: 0px;\n padding: 16px;\n background: #fff;\n}\n.story__point {\n cursor: pointer;\n color: rgba(0, 0, 0, 0.54);\n outline: none;\n height: 48px !important;\n min-height: 48px !important;\n}\n.story__point .md-button {\n padding-left: 32px !important;\n min-height: 48px !important;\n height: 48px !important;\n}\n.story__point.active {\n color: #448aff;\n}\n.story__list {\n overflow: scroll;\n}\n.story__list .story__list-item {\n font-size: 14px !important;\n}\n.button__close-sidebar {\n margin-right: 16px;\n color: rgba(0, 0, 0, 0.54);\n}\n.section__select {\n padding: 0 16px;\n}\n.section__select h2 {\n font-size: 16px;\n font-weight: 500;\n color: rgba(0, 0, 0, 0.54);\n margin: 8px 0;\n}\n.section__select md-select {\n display: inline-block;\n}\n.section__select span {\n color: rgba(0, 0, 0, 0.54);\n text-transform: capitalize;\n}\n.md-subheader-wrapper:not(.md-sticky-no-effect)[sticky-state=active] {\n box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 3px;\n}\n.sb-logo {\n width: 65px;\n height: 60px;\n background-size: 40px;\n background-repeat: no-repeat;\n background-position: 50%;\n background-image: url();\n}\n", ""]); // exports @@ -80615,7 +80457,7 @@ /* 397 */ /***/ function(module, exports, __webpack_require__) { - /* WEBPACK VAR INJECTION */(function(process) {'use strict'; + 'use strict'; Object.defineProperty(exports, "__esModule", { value: true @@ -80640,7 +80482,7 @@ this.$rootScope = $rootScope; - if (process && process.env && process.env.TYPE === 'react') { + if (window.sbtype === 'react') { this.errorMessage = 'Sorry but for now SB not support live component editor for React. We work on this. Stay tuned!'; } else { @@ -80709,19 +80551,13 @@ this.renderError = false; - // We need original template for prevent changes - // So store original component - this.originalComponent = component; - - // Store copy of component - this.component = angular.copy(component); + this.component = component; } }]); return TemplateController; }(); exports.default = TemplateController; - /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(295))) /***/ }, /* 398 */ @@ -80832,19 +80668,25 @@ this.$parse = $parse; - // Listen for new component data and render it - this.listener = $rootScope.$on('render', function (event, component) { - _this.render(event, component); - }); + if (window.sbtype === 'react') { + this.errorMessage = 'Sorry but for now SB not support live component editor for React. We work on this. Stay tuned!'; + } else { - // ACE editor settings - this.settings = { - mode: 'json', - useWrapMode: true, - onLoad: this.onEditorChange.bind(this) - }; - this.$rootScope = $rootScope; - this.inFirst = true; + // Listen for new component data and render it + this.listener = $rootScope.$on('render', function (event, component) { + _this.render(event, component); + }); + + // ACE editor settings + this.settings = { + mode: 'json', + useWrapMode: true, + onLoad: this.onEditorChange.bind(this) + }; + this.$rootScope = $rootScope; + this.inFirst = true; + this.errorMessage = 'Unable to load your model. Please double check it.'; + } } (0, _createClass3.default)(ModelController, [{