Created
July 4, 2017 12:31
-
-
Save Thanood/3e32f3ffbb10755250790636f569619e to your computer and use it in GitHub Desktop.
Aurelia-Materialize bridge chips editor events
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<template> | |
<require from="./logger"></require> | |
<div md-chips="data.bind: chips; placeholder:+tag;" change.delegate="logChange($event.detail)" selected.delegate="logSelect($event.detail)"></div> | |
<div> | |
<!-- chip data: ${chips|stringify} --> | |
chip data: | |
<ul> | |
<li repeat.for="chip of chips"> | |
${chip.tag} | |
</li> | |
</ul> | |
</div> | |
<button md-button md-waves="color: light;" click.delegate="addChip()">Add a chip</button> | |
<button md-button md-waves="color: light;" click.delegate="removeChip()">Remove last chip</button> | |
<div> | |
<logger class="z-depth-1" view-model.ref="logger"></logger> | |
</div> | |
</template> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
export class App { | |
chips = [{ | |
tag: 'Apple' | |
}, { | |
tag: 'Microsoft' | |
}, { | |
tag: 'Google' | |
}]; | |
addChip() { | |
this.chips = this.chips.concat({ tag: 'new chip'}); | |
} | |
removeChip() { | |
this.chips = this.chips.slice(0, this.chips.length - 1); | |
} | |
logChange(detail) { | |
this.logger.log(`chips changed: ${JSON.stringify(detail)}`) | |
} | |
logSelect(detail) { | |
this.logger.log(`chip selected: ${JSON.stringify(detail)}`) | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!doctype html> | |
<html> | |
<head> | |
<title>Aurelia</title> | |
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet"> | |
<meta name="viewport" content="width=device-width, initial-scale=1"> | |
</head> | |
<body aurelia-app="main"> | |
<h1>Loading...</h1> | |
<script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.19.6/system.js"></script> | |
<script src="https://rawgit.com/aurelia-ui-toolkits/aurelia-materialize-bundles/0.20.2/config2.js"></script> | |
<script> | |
System.import('aurelia-bootstrapper'); | |
</script> | |
</body> | |
</html> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<template> | |
<div class="console"> | |
</div> | |
</template> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
export class Logger { | |
attached() { | |
this.overrideStyles(); | |
} | |
log(message, isError, container) { | |
let lastContainer = $('.console div:first', container); | |
let counter = lastContainer.find('.count').detach(); | |
let lastMessage = lastContainer.text(); | |
let count = 1 * (counter.text() || 1); | |
lastContainer.append(counter); | |
if (!lastContainer.length || message !== lastMessage) { | |
$('<div' + (isError ? ' class=\'error\'' : '') + '/>') | |
.css({ | |
marginTop: -24, | |
backgroundColor: isError ? '#ffbbbb' : '#b2ebf2' | |
}) | |
.html(message) | |
.prependTo($('.console', container)) | |
.animate({ marginTop: 0 }, 300) | |
.animate({ backgroundColor: isError ? '#ffdddd' : '#ffffff' }, 800); | |
} else { | |
count++; | |
if (counter.length) { | |
counter.html(count); | |
} else { | |
lastContainer.html(lastMessage) | |
.append('<span class=\'count\'>' + count + '</span>'); | |
} | |
} | |
} | |
error(message) { | |
this.log(message, true); | |
} | |
overrideStyles() { | |
jQuery.each(['backgroundColor', 'borderBottomColor', 'borderLeftColor', 'borderRightColor', 'borderTopColor', 'color', 'outlineColor'], function(i, attr) { | |
jQuery.fx.step[attr] = function(fx) { | |
if (!fx.state || typeof fx.end === typeof '') { | |
fx.start = getColor(fx.elem, attr); | |
fx.end = getRGB(fx.end); | |
} | |
fx.elem.style[attr] = ['rgb(', [ | |
Math.max(Math.min(parseInt((fx.pos * (fx.end[0] - fx.start[0])) + fx.start[0], 10), 255), 0), | |
Math.max(Math.min(parseInt((fx.pos * (fx.end[1] - fx.start[1])) + fx.start[1], 10), 255), 0), | |
Math.max(Math.min(parseInt((fx.pos * (fx.end[2] - fx.start[2])) + fx.start[2], 10), 255), 0) | |
].join(','), ')'].join(''); | |
}; | |
}); | |
} | |
} | |
// Color Conversion functions from highlightFade | |
// By Blair Mitchelmore | |
// http://jquery.offput.ca/highlightFade/ | |
// Parse strings looking for color tuples [255,255,255] | |
function getRGB(color) { | |
let result; | |
// Check if we're already dealing with an array of colors | |
if (color && color.constructor === Array && color.length === 3) { | |
return color; | |
} | |
// Look for rgb(num,num,num) | |
result = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(color); | |
if (result) { | |
return [parseInt(result[1], 10), parseInt(result[2], 10), parseInt(result[3], 10)]; | |
} | |
// Look for #a0b1c2 | |
result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(color); | |
if (result) { | |
return [parseInt(result[1], 16), parseInt(result[2], 16), parseInt(result[3], 16)]; | |
} | |
// Otherwise, we're most likely dealing with a named color | |
return jQuery.trim(color).toLowerCase(); | |
} | |
function getColor(elem, attr) { | |
let color; | |
do { | |
color = jQuery.css(elem, attr); | |
// Keep going until we find an element that has color, or we hit the body | |
if (color && color !== 'transparent' || jQuery.nodeName(elem, 'body')) { | |
break; | |
} | |
attr = 'backgroundColor'; | |
elem = elem.parentNode; | |
} while (elem); | |
return getRGB(color); | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* The following two lines enable async/await without using babel's | |
* "runtime" transformer. Uncomment the lines if you intend to use async/await. | |
* | |
* More info here: https://github.com/jdanyow/aurelia-plunker/issues/2 | |
*/ | |
//import regeneratorRuntime from 'babel-runtime/regenerator'; | |
//window.regeneratorRuntime = regeneratorRuntime; | |
/******************************************************************************/ | |
import 'materialize'; | |
export function configure(aurelia) { | |
aurelia.use | |
.standardConfiguration() | |
.developmentLogging() | |
.plugin('aurelia-materialize-bridge', bridge => bridge.useAll() ); | |
aurelia.start().then(a => a.setRoot()); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment