Skip to content

Instantly share code, notes, and snippets.

@offirgolan
Created September 7, 2017 20:33
Show Gist options
  • Save offirgolan/6359b8f1279571099bf4c6cd8c025469 to your computer and use it in GitHub Desktop.
Save offirgolan/6359b8f1279571099bf4c6cd8c025469 to your computer and use it in GitHub Desktop.
Middle Truncate
import Ember from 'ember';
export default Ember.Controller.extend({
appName: 'Ember Twiddle'
});
import Ember from 'ember';
const {
isPresent
} = Ember;
export function truncate([ value = '', length = 10 ], { separator = '...' }) {
if (!isPresent(value) || value.length <= length) {
return value;
}
const charsToShow = length - separator.length;
const frontChars = Math.ceil(charsToShow / 2);
const backChars = Math.floor(charsToShow / 2);
return `${value.substr(0, frontChars)}${separator}${value.substr(value.length - backChars)}`;
}
export default Ember.Helper.helper(truncate);
<h1>Welcome to {{appName}}</h1>
<br>
<br>
{{outlet}}
<br>
<br>
{{truncate 'Please Haters Back Off: Season 2' 20}}
{
"version": "0.12.1",
"EmberENV": {
"FEATURES": {}
},
"options": {
"use_pods": false,
"enable-testing": false
},
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "2.12.0",
"ember-template-compiler": "2.12.0",
"ember-testing": "2.12.0"
},
"addons": {
"ember-data": "2.12.1"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment