#Angular
"@" ( Text binding / one-way binding )
"=" ( Direct model binding / two-way binding )
"&" ( Behaviour binding / Method binding )
"?" = optionnal (no inheritance from parent scope)
/**** Utils ****/ | |
.font(@size) { | |
font-size: @size; | |
line-height: @size; | |
} | |
.size(@width, @height) { | |
width: @width; | |
height: @height; | |
} |
var gulp = require('gulp'); | |
var sourcemaps = require('gulp-sourcemaps'); | |
var source = require('vinyl-source-stream'); | |
var buffer = require('vinyl-buffer'); | |
var browserify = require('browserify'); | |
var watchify = require('watchify'); | |
var babel = require('babelify'); | |
var sass = require('gulp-sass'); | |
function compile(watch) { |
http://ricostacruz.com/cheatsheets/semver.html
Given a version number MAJOR.MINOR.PATCH
:
-MAJOR
= incompatible API changes.
-MINOR
= add functionality. (backwards-compatible)
-PATCH
= bug fixes. (backwards-compatible)
For each call ajax
English
var msg = new SpeechSynthesisUtterance('Hello! how are you today?');
msg.lang = 'en-US';
window.speechSynthesis.speak(msg);
French
var msg = new SpeechSynthesisUtterance("Bonjour, comment allez vous aujourd'hui?");
<!DOCTYPE html> | |
<html> | |
<body> | |
<img src=" |
import { Action, ActionReducer, Store } from '@ngrx/store'; | |
import { BehaviorSubject } from 'rxjs/BehaviorSubject'; | |
import { Observable } from 'rxjs/Observable'; | |
import { map } from 'rxjs/operator/map'; | |
import { Observer } from 'rxjs/Observer'; | |
// TODO: How to initialize those variables? | |
const dispatcherMock: Observer<Action>, | |
reducerMock: Observer<ActionReducer<any>>, | |
stateMock: Observable<any>; |
export function createTranslateLoader(http: HttpClient) { | |
return new TranslateHttpLoader(http, './assets/i18n/app/', '.json'); | |
} | |
@NgModule({ | |
imports: [ | |
/* ... */ | |
HttpClientModule, | |
TranslateModule.forRoot({ | |
loader: { |