Commit c39d2394 authored by Frank's avatar Frank
Browse files

ff version

parent 5b25c0f8
Pipeline #86109559 passed with stage
in 55 seconds
Authors ordered by first contribution.
Frank Thürigen <fthuerigen@googlemail.com>
Francisc Simon <francisc@simon.services>
Honourable mentions.
John Resig - I loved our discussions about JS coding principles back in 2005 - FTH.
Copyright twoBirds Foundation contributors
This software consists of voluntary contributions made by many
individuals. For exact contribution history, see the revision history
available at https://github.com/jquery/jquery
The following license applies to all parts of this software except as
documented below:
====
Permission is hereby granted, free of charge, to any person obtaining
a copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
====
All files located in the node_modules and external directories are
externally maintained libraries used by this software which have their
own licenses; we recommend you read them, as their terms may differ from
the terms above.
\ No newline at end of file
app.Mist = class Mist extends Tb{
constructor(){
super();
let that = this;
that.handlers = {
init: that.init
};
}
get template(){ return `
<p>app-mist test template</p>`;
}
// omitted if autonomous custom element
get namespace(){
return 'app.Mist';
}
// methods
init(){
let that = this;
$(that.target)
.append( $(that.template.trim()) );
}
};
{ "data": { "a": 2 } }
body { overflow-y: scroll; }
.jasmine_html-reporter { background-color: #eee; padding: 5px; margin: -8px; font-size: 11px; font-family: Monaco, "Lucida Console", monospace; line-height: 14px; color: #333; }
.jasmine_html-reporter a { text-decoration: none; }
.jasmine_html-reporter a:hover { text-decoration: underline; }
.jasmine_html-reporter p, .jasmine_html-reporter h1, .jasmine_html-reporter h2, .jasmine_html-reporter h3, .jasmine_html-reporter h4, .jasmine_html-reporter h5, .jasmine_html-reporter h6 { margin: 0; line-height: 14px; }
.jasmine_html-reporter .jasmine-banner, .jasmine_html-reporter .jasmine-symbol-summary, .jasmine_html-reporter .jasmine-summary, .jasmine_html-reporter .jasmine-result-message, .jasmine_html-reporter .jasmine-spec .jasmine-description, .jasmine_html-reporter .jasmine-spec-detail .jasmine-description, .jasmine_html-reporter .jasmine-alert .jasmine-bar, .jasmine_html-reporter .jasmine-stack-trace { padding-left: 9px; padding-right: 9px; }
.jasmine_html-reporter .jasmine-banner { position: relative; }
.jasmine_html-reporter .jasmine-banner .jasmine-title { background: url('') no-repeat; background: url('') no-repeat, none; -moz-background-size: 100%; -o-background-size: 100%; -webkit-background-size: 100%; background-size: 100%; display: block; float: left; width: 90px; height: 25px; }
.jasmine_html-reporter .jasmine-banner .jasmine-version { margin-left: 14px; position: relative; top: 6px; }
.jasmine_html-reporter #jasmine_content { position: fixed; right: 100%; }
.jasmine_html-reporter .jasmine-version { color: #aaa; }
.jasmine_html-reporter .jasmine-banner { margin-top: 14px; }
.jasmine_html-reporter .jasmine-duration { color: #fff; float: right; line-height: 28px; padding-right: 9px; }
.jasmine_html-reporter .jasmine-symbol-summary { overflow: hidden; *zoom: 1; margin: 14px 0; }
.jasmine_html-reporter .jasmine-symbol-summary li { display: inline-block; height: 10px; width: 14px; font-size: 16px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-passed { font-size: 14px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-passed:before { color: #007069; content: "\02022"; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-failed { line-height: 9px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-failed:before { color: #ca3a11; content: "\d7"; font-weight: bold; margin-left: -1px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-disabled { font-size: 14px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-disabled:before { color: #bababa; content: "\02022"; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-pending { line-height: 17px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-pending:before { color: #ba9d37; content: "*"; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-empty { font-size: 14px; }
.jasmine_html-reporter .jasmine-symbol-summary li.jasmine-empty:before { color: #ba9d37; content: "\02022"; }
.jasmine_html-reporter .jasmine-run-options { float: right; margin-right: 5px; border: 1px solid #8a4182; color: #8a4182; position: relative; line-height: 20px; }
.jasmine_html-reporter .jasmine-run-options .jasmine-trigger { cursor: pointer; padding: 8px 16px; }
.jasmine_html-reporter .jasmine-run-options .jasmine-payload { position: absolute; display: none; right: -1px; border: 1px solid #8a4182; background-color: #eee; white-space: nowrap; padding: 4px 8px; }
.jasmine_html-reporter .jasmine-run-options .jasmine-payload.jasmine-open { display: block; }
.jasmine_html-reporter .jasmine-bar { line-height: 28px; font-size: 14px; display: block; color: #eee; }
.jasmine_html-reporter .jasmine-bar.jasmine-failed { background-color: #ca3a11; }
.jasmine_html-reporter .jasmine-bar.jasmine-passed { background-color: #007069; }
.jasmine_html-reporter .jasmine-bar.jasmine-skipped { background-color: #bababa; }
.jasmine_html-reporter .jasmine-bar.jasmine-errored { background-color: #ca3a11; }
.jasmine_html-reporter .jasmine-bar.jasmine-menu { background-color: #fff; color: #aaa; }
.jasmine_html-reporter .jasmine-bar.jasmine-menu a { color: #333; }
.jasmine_html-reporter .jasmine-bar a { color: white; }
.jasmine_html-reporter.jasmine-spec-list .jasmine-bar.jasmine-menu.jasmine-failure-list, .jasmine_html-reporter.jasmine-spec-list .jasmine-results .jasmine-failures { display: none; }
.jasmine_html-reporter.jasmine-failure-list .jasmine-bar.jasmine-menu.jasmine-spec-list, .jasmine_html-reporter.jasmine-failure-list .jasmine-summary { display: none; }
.jasmine_html-reporter .jasmine-results { margin-top: 14px; }
.jasmine_html-reporter .jasmine-summary { margin-top: 14px; }
.jasmine_html-reporter .jasmine-summary ul { list-style-type: none; margin-left: 14px; padding-top: 0; padding-left: 0; }
.jasmine_html-reporter .jasmine-summary ul.jasmine-suite { margin-top: 7px; margin-bottom: 7px; }
.jasmine_html-reporter .jasmine-summary li.jasmine-passed a { color: #007069; }
.jasmine_html-reporter .jasmine-summary li.jasmine-failed a { color: #ca3a11; }
.jasmine_html-reporter .jasmine-summary li.jasmine-empty a { color: #ba9d37; }
.jasmine_html-reporter .jasmine-summary li.jasmine-pending a { color: #ba9d37; }
.jasmine_html-reporter .jasmine-summary li.jasmine-disabled a { color: #bababa; }
.jasmine_html-reporter .jasmine-description + .jasmine-suite { margin-top: 0; }
.jasmine_html-reporter .jasmine-suite { margin-top: 14px; }
.jasmine_html-reporter .jasmine-suite a { color: #333; }
.jasmine_html-reporter .jasmine-failures .jasmine-spec-detail { margin-bottom: 28px; }
.jasmine_html-reporter .jasmine-failures .jasmine-spec-detail .jasmine-description { background-color: #ca3a11; }
.jasmine_html-reporter .jasmine-failures .jasmine-spec-detail .jasmine-description a { color: white; }
.jasmine_html-reporter .jasmine-result-message { padding-top: 14px; color: #333; white-space: pre; }
.jasmine_html-reporter .jasmine-result-message span.jasmine-result { display: block; }
.jasmine_html-reporter .jasmine-stack-trace { margin: 5px 0 0 0; max-height: 224px; overflow: auto; line-height: 18px; color: #666; border: 1px solid #ddd; background: white; white-space: pre; }
var test={},$=tb.dom;tb.assumeTb(!0),test.GrandParent=class extends Tb{constructor(t,e){super(t,e);this.handlers={init:this.init,test:this.test},this.b={}}init(){var t=this,e=$("img",t.target)[0];$(t.target).hide(),t.b.c.d.e=5;for(var s=0;s<5;s++)new tb("test.Parent",{},t.target.insertBefore(document.createElement("div"),e));t.on("ready",()=>$(t.target).show(),!0)}test(t){}},test.TestForm=class extends Tb{constructor(){super();var t=this;t.crud=new tb.CRUD({read:{url:"/test/TestForm.json",method:"GET",success:function(e){var s=JSON.parse(e.text);$("form").values(s),t.formValues=s},error:function(t){console.log("an error occured",t)}}}),tb.require(["/test/TestForm.html","/test/TestForm.css"]).then(t.render.bind(t))}render(){var t=$(tb.require.get("/test/TestForm.html"));$(this.target).append(t),this.formValues={},this.formValues.bind(this.target),$("form").values().bind(this.formValues),this.crud.read()}},test.Parent=class extends Tb{constructor(t,e){super(t,e);this.handlers={init:this.init}}init(){for(var t=0;t<10;t++)new tb("test.Child",{},this.target.appendChild(document.createElement("span")))}},test.Embedded1=class extends Tb{constructor(){super();this.embedded2=new test.Embedded2}},test.Embedded2=class extends Tb{constructor(){super();this.handlers={init:function(t){}}}},test.Child=class extends Tb{constructor(t,e){super(t,e);this.handlers={init:this.init,test:this.test},this.embedded1=new test.Embedded1}init(){for(var t=0;t<3;t++)new tb("test.GrandChild",{},this.target.appendChild(document.createElement("span")))}test(t){t.data instanceof test.Embedded2&&t.stopPropagation()}},test.GrandChild=class extends Tb{constructor(t,e){super(t,e);this.handlers={init:this.init}}init(){for(var t=0;t<2;t++)$(this.target).append("<test-greatgrandchild>")}},tb.createCustomElement("test-greatgrandchild",class extends Tb{constructor(){super();this.handlers={init:this.init,connected:this.connected,disconnected:this.disconnected,attributeChanged:this.attributeChanged,adopted:this.adopted}}init(){this.updateStyle()}updateStyle(){function t(t,e){return Math.floor(Math.random()*(e-t+1)+t)}$(this.target).attr("style","border-color:rgb("+t(0,255)+","+t(0,255)+","+t(0,255)+")")}connected(){}disconnected(){}attributeChanged(t){console.log("attributeChanged",t.data)}adopted(){}},["a","b","c"]);
\ No newline at end of file
/*! twobirds-core - v8.2.7 - 2019-10-02 */
// globals
var test = {}, // repo
$ = tb.dom; // jQuery like selector
tb.assumeTb(true); // treat unknown tags as tb custom element
test.GrandParent = ( class GrandParent extends Tb{
constructor( pConfig, pTarget ){
super( pConfig, pTarget );
var that = this;
that.handlers = {
init: that.init,
test: that.test
};
that.b = {};
}
// methods
init(){
var that = this,
img = $('img', that.target)[0];
$( that.target ).hide();
that.b.c.d.e = 5;
for ( var x=0; x < 5; x++ ) {
new tb(
'test.Parent',
{},
that.target.insertBefore( document.createElement('div'), img )
);
}
// when all children have run their inits
that.on(
'ready',
() => $( that.target ).show(),
true
);
}
test( ev ){
//console.info( ' grandParent:test() reached' );
}
});
test.TestForm = class extends Tb{
constructor(){
super();
var that = this;
// model to read data from
that.crud = new tb.CRUD({
'read': {
url: '/test/TestForm.json', // mock data
method: 'GET',
success: function( pResult ){
var values = JSON.parse( pResult.text );
$('form').values( values ); // set form input values
that.formValues = values; // set values for two way binding
},
error: function( pResult ){
console.log( 'an error occured', pResult );
}
}
});
tb.require([
'/test/TestForm.html',
'/test/TestForm.css'
]).then(
that.render.bind(that)
);
}
// methods
render(){
var that = this,
fragment = $( tb.require.get('/test/TestForm.html') );
// add fragment to DOM
$( that.target )
.append( fragment );
// create formValues store
that.formValues = {};
// update DOM on formValues change
that.formValues.bind( that.target );
// update formValues store when form content is changed
$('form').values().bind( that.formValues );
// read data
that.crud.read();
}
};
test.Parent = ( class Parent extends Tb{
constructor( pConfig, pTarget ){
super( pConfig, pTarget );
var that = this;
that.handlers = {
init: that.init
};
}
// methods
init(){
var that = this;
for ( var x=0; x < 10; x++ ) {
new tb(
'test.Child',
{},
that.target.appendChild( document.createElement('span') )
);
}
}
});
// simple internal classes...
test.Embedded1 = ( class Embedded1 extends Tb{
constructor(){
super();
var that = this;
that.embedded2 = new test.Embedded2();
}
});
test.Embedded2 = ( class Embedded2 extends Tb{
constructor(){
super();
var that = this;
that.handlers = {
'init': function( e ){
var that = this;
//that.trigger( 'test', that, 'u');
}
}
}
});
test.Child = ( class Child extends Tb{
constructor( pConfig, pTarget ){
super( pConfig, pTarget );
var that = this;
that.handlers = {
init: that.init,
test: that.test
};
that.embedded1 = new test.Embedded1();
}
// methods
init(){
var that = this;
for ( var x=0; x < 3; x++ ) {
new tb(
'test.GrandChild',
{},
that.target.appendChild( document.createElement('span') )
);
}
}
test( e ){
var that = this;
if ( e.data instanceof test.Embedded2 ){
e.stopPropagation();
}
//console.info( 'child ::test() reached' );
}
});
test.GrandChild = ( class GrandChild extends Tb{
constructor( pConfig, pTarget ){
super( pConfig, pTarget );
var that = this;
that.handlers = {
init: that.init
};
}
// methods
init(){
var that = this;
for ( var x=0; x < 2; x++ ) {
$(that.target).append('<test-greatgrandchild>');
}
}
});
tb.createCustomElement(
'test-greatgrandchild',
class extends Tb{
constructor(){
super();
var that = this;
that.handlers = {
init: that.init,
connected: that.connected,
disconnected: that.disconnected,
attributeChanged: that.attributeChanged,
adopted: that.adopted
};
}
// methods
init(){
var that = this;
that.updateStyle();
//that.trigger( 'test', that, 'u' );
}
updateStyle(){
var that = this;
function random(min,max) {
var random = Math.floor(Math.random()*(max-min+1)+min);
return random;
}
function randomBorderColor(){
return 'rgb(' + random(0,255) + ',' + random(0,255) + ',' + random(0,255) + ')';
}
$(that.target).attr('style', 'border-color:'+randomBorderColor() );
}
connected(){
var that = this;
//console.log('connected', that.target);
}
disconnected(){
var that = this;
//console.log('disconnected', that.target);
}
attributeChanged(ev){
var that = this;
console.log('attributeChanged', ev.data);
}
adopted(){
var that = this;
//console.log('adopted', that.target);
}
},
[ 'a', 'b', 'c'] // watched attributes
);
This diff is collapsed.
This source diff could not be displayed because it is too large. You can view the blob instead.
This diff is collapsed.
<!DOCTYPE html>
<html>
<head>
<title>tb manual testing</title>
<link rel="stylesheet" type="text/css" href="jasmine/jasmine.css">
<link rel="stylesheet" type="text/css" href="test/GrandParent.css">
<script type="text/javascript" src="tb/tb-min.js"></script>
<script type="text/javascript" src="repo-min.js"></script>
<script>
tb.idle(
function(){
setTimeout(function(){
// run tests
tb.Require([
'tbTest.js'
]);
},1000);
}
);
// svg favicon
setTimeout(function(){
// make svg favicon
var $ = tb.dom,
$c = $('<canvas>'),
i = new Image();
function loaded(){
//set canvas to image size
$c.attr({
height: i.height,
width: i.width
});
// get context
var ctx = $c[0].getContext('2d');
ctx.globalCompositeOperation = 'copy';
ctx.drawImage(i, 0, 0, $c.attr('width'), $c.attr('height'));
// copy context content to link node
$('<link rel="icon">')
.attr(
'href',
$c[0].toDataURL()
)
.appendTo(
document.head
);
}
i.addEventListener('load', loaded)
i.src = '/twoBirds.svg';
}, 5000);
</script>
</head>
<body data-tb="test.GrandParent">
<img style="position:fixed;top:10px;right:10px;z-index:-1" src="/twoBirds.svg"/>
<form style="background-color:{colorInput};" data-tb="test.TestForm" /></form>
</body>
</html>
{
"status": "ok"
}
\ No newline at end of file
[data-tb~="test.GrandParent"] {
border: 0px none;
background-color: #eaf8f8;
}
[data-tb*="Parent"],
.jasmine_html-reporter {
padding: 2px;
margin: 2px;
display: block;
border: 1px solid darkslategrey;
border-radius: 3px;
}
[data-tb*="Child"],
test-greatgrandchild {
display: inline-block;
padding: 2px;
margin: 2px;
border: 1px solid darkslategray;
}
.jasmine_html-reporter {
background-color: transparent;
display: block;
clear: both;
}
/*# sourceMappingURL=GrandParent.css.map */
{
"version": 3,
"mappings": "AAAA;sBACuB;EACrB,OAAO,EAAE,GAAG;EACZ,MAAM,EAAE,IAAI;EACZ,MAAM,EAAE,eAAe;EACvB,gBAAgB,EAAE,YAAY;;AAGhC,gBAAiB;EACf,OAAO,EAAE,YAAY;EACrB,OAAO,EAAE,GAAG;EACZ,MAAM,EAAE,GAAG;EACX,MAAM,EAAE,uBAAuB;EAC/B,gBAAgB,EAAE,YAAY",
"sources": ["scss/GrandParent.scss"],
"names": [],
"file": "GrandParent.css"
}
\ No newline at end of file
legend {
display: inherit;
margin: inherit;
vertical-align: inherit;
}
label {
display: inline;
margin-top: 5px;
margin-left: 5px;
vertical-align: top;
width: 10em;
text-align: right;
}
label::before {