'use strict';


	var htmlEscapes = {
		'&': '&',
		'<': '<',
		'>': '>',
		'"': '"',
		'\'': ''',
		'`': '`'
	};


	var escapeHtmlChar = function (chr) {
		return htmlEscapes[chr];
	};

	var reUnescapedHtml = /[&<>"'`]/g;
	var reHasUnescapedHtml = new RegExp(reUnescapedHtml.source);

	var escape = function (string) {
		return (string && reHasUnescapedHtml.test(string))
			? string.replace(reUnescapedHtml, escapeHtmlChar)
			: string;
	};


	/**
	 * Définit le template par défaut
	 * @constructor
	 */
	function Template() {
		this.defaultTemplate
		=	'&lt;li data-id="{{id}}" class="{{completed}}">'
		+		'&lt;div class="view">'
		+			'&lt;input class="toggle" type="checkbox" {{checked}}>'
		+			'&lt;label>{{title}}&lt;/label>'
		+			'&lt;button class="destroy">&lt;/button>'
		+		'&lt;/div>'
		+	'&lt;/li>';
	}

	/**
	 * Récupère le template et y injecte les données du ToDo.
	 * @param {object} (data) Les données.
	 * @returns {string} Template HTML correspondant à l' élément &lt;li>
	 *
	 * @example
	 * view.show({
	 *	id: 1,
	 *	title: "Hello World",
	 *	completed: 0,
	 * });
	 */
	Template.prototype.show = function (data) {
		var i, l;
		var view = '';

		for (i = 0, l = data.length; i < l; i++) {
			var template = this.defaultTemplate;
			var completed = '';
			var checked = '';

			if (data[i].completed) {
				completed = 'completed';
				checked = 'checked';
			}

			template = template.replace('{{id}}', data[i].id);
			template = template.replace('{{title}}', escape(data[i].title));
			template = template.replace('{{completed}}', completed);
			template = template.replace('{{checked}}', checked);

			view = view + template;
		}

		return view;
	};


	/**
	 * Affiche le nombre de ToDos.
	 * @param {number} (activeTodos) Le nombre de ToDos actifs.
	 * @returns {string} Chaîne contenant l'affichage du compteur.
	 */
	Template.prototype.itemCounter = function (activeTodos) {
		var plural = activeTodos === 1 ? '' : 's';

		return '&lt;strong>' + activeTodos + '&lt;/strong> item' + plural + ' left';
	};


	/**
	 * Affiche le bouton 'ClearCompleted'.
	 * @param  {number} (completedTodos) Le nombre de ToDos complétés.
	 * @returns {string} Chaîne à afficher.
	 */
	Template.prototype.clearCompletedButton = function (completedTodos) {
		if (completedTodos > 0) {
			return 'Clear completed';
		} else {
			return '';
		}
	};

	window.app = window.app || {};
	window.app.Template = Template;