diff options
author | Emmanuel ROHEE <erohee@amdocs.com> | 2014-08-14 11:36:11 +0200 |
---|---|---|
committer | Emmanuel ROHEE <erohee@amdocs.com> | 2014-08-14 11:36:11 +0200 |
commit | 7dc0a28e17bff5172c303497b6c1ca40af23e7e9 (patch) | |
tree | 38648495ef21814d2d516e79d889d57269f5d4c9 /webclient/components/fileInput | |
parent | grammar fix (diff) | |
download | synapse-7dc0a28e17bff5172c303497b6c1ca40af23e7e9.tar.xz |
Created m-file-input. A directive to open a file selection dialog on whatever HTML element
Diffstat (limited to 'webclient/components/fileInput')
-rw-r--r-- | webclient/components/fileInput/file-input-directive.js | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/webclient/components/fileInput/file-input-directive.js b/webclient/components/fileInput/file-input-directive.js new file mode 100644 index 0000000000..9b73f877e9 --- /dev/null +++ b/webclient/components/fileInput/file-input-directive.js @@ -0,0 +1,43 @@ +/* + Copyright 2014 matrix.org + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + */ + +'use strict'; + +/* + * Transform an element into an image file input button. + * Watch to the passed variable change. It will contain the selected HTML5 file object. + */ +angular.module('mFileInput', []) +.directive('mFileInput', function() { + return { + restrict: 'A', + transclude: 'true', + template: '<div ng-transclude></div><input ng-hide="true" type="file" accept="image/*"/>', + scope: { + selectedFile: '=mFileInput' + }, + + link: function(scope, element, attrs, ctrl) { + element.bind("click", function() { + element.find("input")[0].click(); + element.find("input").bind("change", function(e) { + scope.selectedFile = this.files[0]; + scope.$apply(); + }); + }); + } + }; +}); \ No newline at end of file |