summaryrefslogtreecommitdiffstats
path: root/afb-client/app/Frontend/widgets/FormInput
diff options
context:
space:
mode:
Diffstat (limited to 'afb-client/app/Frontend/widgets/FormInput')
-rw-r--r--afb-client/app/Frontend/widgets/FormInput/InputPassword.js79
-rw-r--r--afb-client/app/Frontend/widgets/FormInput/InputText.js179
-rw-r--r--afb-client/app/Frontend/widgets/FormInput/UploadFiles.js2
3 files changed, 1 insertions, 259 deletions
diff --git a/afb-client/app/Frontend/widgets/FormInput/InputPassword.js b/afb-client/app/Frontend/widgets/FormInput/InputPassword.js
deleted file mode 100644
index 157009c..0000000
--- a/afb-client/app/Frontend/widgets/FormInput/InputPassword.js
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (C) 2015 "IoT.bzh"
- * Author "Fulup Ar Foll"
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-(function() {
-'use strict';
-
-var tmpl = '<input-text class="password" tip="{{tip1}}" placeholder="{{place1}}"' +
- 'label="{{label1}}" callback="valid1" name="{{name}}-1" value="pass1" required minlen="{{minlen}}" type="password" >' +
- '</input-text>' +
- '<input-text class="password" tip="tip2" placeholder="{{place2}}"' +
- 'label="{{label2}}" callback="valid2" name="{{name}}-2" value="pass2" required minlen="{{minlen}}" type="password" > '+
- '</input-text>';
-
-angular.module('InputPassword',[])
-
-.directive('inputPassword', function() {
- function mymethods(scope, elem, attrs) {
-
- scope.valid1 = function (name, value) {
- console.log ("Clicked InputPassword1 name=%s value=%s", name, value);
- scope.firstpwd = value;
- };
-
- scope.valid2 = function (name, value, done) {
- console.log ("Clicked InputPassword2 name=%s value=%s", name, value);
-
- // if both passwd equal then call form CB
- if (scope.firstpwd !== value) {
- done({valid: false, status: 'invalid', errmsg: "both password should match"});
- } else {
- scope.callback (attrs.name, value);
- }
-
- };
-
- // this method can be called from controller to update widget status
- scope.done=function (data) {
- console.log ("Text-Input Callback ID="+ attrs.name + " data=", data);
- for (var i in data) scope[i] = data[i];
- };
-
- // Export some attributes within directive scope for template
- scope.name = attrs.name;
- scope.label1 = attrs.label || 'Password';
- scope.label2 = attrs.label || 'Password Verification';
- scope.place1 = attrs.placeholder1 || 'User Password';
- scope.tip1 = attrs.tip || 'Choose a Password';
- scope.place2 = attrs.placeholder1 || 'Password Verification';
- scope.tip2 = attrs.tip || 'Confirme your Password';
- scope.minlen = attrs.minlen || 10;
-
- if ("required" in attrs) scope.required = 'required';
-
- }
-
- return {
- restrict: 'E',
- template: tmpl,
- link: mymethods,
- scope: {
- callback : '=',
- }
- };
-});
-
-console.log ("InputPassword Loaded");
-})();
diff --git a/afb-client/app/Frontend/widgets/FormInput/InputText.js b/afb-client/app/Frontend/widgets/FormInput/InputText.js
deleted file mode 100644
index 2653175..0000000
--- a/afb-client/app/Frontend/widgets/FormInput/InputText.js
+++ /dev/null
@@ -1,179 +0,0 @@
-
-/*
- * Copyright (C) 2015 "IoT.bzh"
- * Author "Fulup Ar Foll"
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details..
- */
-
-
-
-(function() {
-'use strict';
-
-var tmpl = '<tip-modal tip="tip"></tip-modal>' +
- '<label for="{{name}}-intext">{{label}} <i ng-show="required" ng-click="ToBeDefined" ' +
- 'class="required {{status}} fi-checkbox" title="Free Value But Mandatory Argument" alt="?"> &nbsp; </i></label>'+
- '<input '+
- ' type="{{type}}" id="{{name}}-intext" placeholder="{{placeholder}}" class="status-{{status}}"'+
- ' ng-model="value" ng-blur="validate()" ng-focus="selected()" '+
- ' ng-model-options="{ updateOn: \'default blur\', debounce: {default: 500, blur: 0} }"' +
- '><alert data-ng-show="!valid&&errmsg">{{errmsg}}</alert>';
-
-var emailpatern = /^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i;
-
-angular.module('InputText',['JQueryEmu'])
-
-.directive('inputText', function(JQemu) {
- function mymethods(scope, elem, attrs) {
-
- // default value at 1st rendering
- scope.error = false;
- scope.valid = false;
- scope.status = 'untouch';
-
- scope.input = elem.find ("input");
- scope.required = 0;
-
- // requirer is use to increment requested counter
- if ("required" in attrs) {
- scope.required = 1;
- elem.addClass ("required");
- }
-
- // user enter input reset error status
- scope.selected = function () {
- scope.error=false;
- scope.errmsg=false;
- scope.status = 'touch';
- };
-
- scope.validate = function () {
-
- // get value from input field bypassing Angular ng-model
- console.log ("Clicked InputText name=%s value=%s valid=%s", scope.name, scope.value, scope.valid);
-
- // form is not untouched anymore
- scope.parent.removeClass ("ng-pristine");
-
- // if value not null clean up string
- if (scope.value) {
- scope.error=false;
- // remove leading and trailling space
- scope.value = scope.value.trim();
-
- // remove any space is not allowed
- if ('nospace' in attrs) {
- scope.value=scope.value.replace(/\s/g, '');
- }
-
- if ('lowercase' in attrs) {
- scope.value = scope.value.toLowerCase();
- }
-
- // check minimum lenght
- if ("minlen" in attrs) {
- if (scope.value.length < attrs.minlen) {
- scope.status='invalid';
- scope.errmsg=scope.name + ': Mininum Lengh= ' + attrs.minlen + ' Characters';
- scope.error=true;
- }
- }
-
- if ('email' in attrs) {
- if (!emailpatern.test (scope.value)) {
- scope.status='invalid';
- scope.errmsg='invalid email address';
- scope.error=true;
- }
- }
-
- } else {
- if (scope.required) {
- scope.status='invalid';
- scope.errmsg=scope.name + ': Required Attribute';
- scope.error=true;
- }
- }
-
- // If local control fail let's refuse input
- if (scope.error) {
- if (scope.required && scope.valid) {
- scope.valid = false;
- if (scope.l4acounter.validated > 0) scope.l4acounter.validated --;
- }
- // use call to update form scope on form completeness
- scope.callback (attrs.name, null, scope.done);
- } else {
- // localcheck is OK backup may nevertheless change status to false
- if (scope.required && !scope.valid) scope.l4acounter.validated ++;
- scope.status='valid';
- scope.valid=true;
- scope.callback (attrs.name, scope.value, scope.done);
- }
-
- };
-
- // this method can be called from controller to update widget status
- scope.done=function (data) {
- console.log ("Text-Input Callback ID="+ attrs.name + " data=", data);
- for (var i in data) scope[i] = data[i];
- };
-
- // Export some attributes within directive scope for template
- scope.label = attrs.label;
- scope.name = attrs.name;
- scope.placeholder = attrs.placeholder;
- scope.type = attrs.type || "text";
- scope.tip = attrs.tip;
-
- // search for form within parent elemnts
- scope.parent = JQemu.parent (elem, "FORM");
-
- // email enforce lowercase and nospace
- if ("email" in attrs) {
- attrs.lowercase=true;
- attrs.nospace=true;
- attrs.minlen=6;
- }
-
- if (scope.required) {
- scope.l4acounter = scope.parent.data ("l4acounter");
- if (!scope.l4acounter) {
- scope.l4acounter = {required:1, validated:0};
- console.log("Field "+scope.name+" is required (1st)");
- scope.parent.data ("l4acounter", scope.l4acounter);
- } else {
- console.log("Field "+scope.name+" is required");
- scope.l4acounter.required ++;
- }
- }
-
- // refresh validation each time controler update value
- scope.$watch ('value', function(){
- if(scope.value) scope.validate(); }
- );
-
- }
-
- return {
- restrict: 'E',
- template: tmpl,
- link: mymethods,
- scope: {
- callback : '=',
- value: '='
- }
- };
-});
-
-console.log ("InputText Loaded");
-})();
diff --git a/afb-client/app/Frontend/widgets/FormInput/UploadFiles.js b/afb-client/app/Frontend/widgets/FormInput/UploadFiles.js
index a23809f..90110c9 100644
--- a/afb-client/app/Frontend/widgets/FormInput/UploadFiles.js
+++ b/afb-client/app/Frontend/widgets/FormInput/UploadFiles.js
@@ -157,7 +157,7 @@ angular.module('UploadFiles',['AppConfig', 'ModalNotification', 'RangeSlider'])
};
// Initiallize default values from attributes values
- scope.name= attrs.name || 'avatar';
+ scope.name= attrs.name || 'file';
scope.category= attrs.category || 'image';
scope.mimetype= (attrs.accept || 'image') + '/*';
scope.maxsize= attrs.maxsize || 100; // default max size 100KB