虚拟键盘字母数字

时间:2019-05-16 20:14:26

标签: jquery keyboard virtual alphanumeric

// jQuery Bootstrap Touch Keyboard plugin
// By Matthew Dawkins
(function($) {
    $.fn.keyboard = function(options) {
        // Settings
        var settings = $.extend({
            keyboardLayout: [
                [
                    ['1', '1'],
                    ['2', '2'],
                    ['3', '3'],
                    ['4', '4'],
                    ['5', '5'],
                    ['6', '6'],
                    ['7', '7'],
                    ['8', '8'],
                    ['9', '9'],
                    ['0', '0'],
                    ['del', 'del']
                ],
                [
                    ['q', 'Q'],
                    ['w', 'W'],
                    ['e', 'E'],
                    ['r', 'R'],
                    ['t', 'T'],
                    ['y', 'Y'],
                    ['u', 'U'],
                    ['i', 'I'],
                    ['o', 'O'],
                    ['p', 'P'],
                    ['-', '='],
                    ['_', '+']
                ],
                [
                    ['a', 'A'],
                    ['s', 'S'],
                    ['d', 'D'],
                    ['f', 'F'],
                    ['g', 'G'],
                    ['h', 'H'],
                    ['j', 'J'],
                    ['k', 'K'],
                    ['l', 'L'],
                    ['\'', ':'],
                    ['@', ';'],
                    ['#', '~']
                ],
                [
                    ['z', 'Z'],
                    ['x', 'X'],
                    ['c', 'C'],
                    ['v', 'V'],
                    ['b', 'B'],
                    ['n', 'N'],
                    ['m', 'M'],
                    [',', ','],
                    ['.', '.'],
                    ['?', '!']
                ],
                [
                    ['shift', 'shift'],
                    ['space', 'space'],
                    ['shift', 'shift']
                ]
            ],
            numpadLayout: [
                [
                    ['7'],
                    ['8'],
                    ['9']
                ],
                [
                    ['4'],
                    ['5'],
                    ['6']
                ],
                [
                    ['1'],
                    ['2'],
                    ['3']
                ],
                [
                    ['del'],
                    ['0'],
                    ['.']
                ]
            ],
            telLayout: [
                [
                    ['1'],
                    ['2'],
                    ['3']
                ],
                [
                    ['4'],
                    ['5'],
                    ['6']
                ],
                [
                    ['7'],
                    ['8'],
                    ['9']
                ],
                [
                    ['del'],
                    ['0'],
                    ['.']
                ]
            ],
            layout: false,
            type: false,
            btnTpl: '<button type="button" tabindex="-1">',
            btnClasses: 'btn btn-sm btn-style-1',
            /* btnActiveClasses: 'active', */
            initCaps: false,
            placement: 'bottom',
            container:'body',
            trigger: 'focus',
            maxLength: '10'
        }, options);
        if (!settings.layout) {
            if (($(this).attr('type') === 'tel' && $(this).hasClass('keyboard-numpad')) || settings.type === 'numpad') {
                settings.layout = settings.numpadLayout;
            } else if (($(this).attr('type') === 'tel') || settings.type === 'tel') {
                settings.layout = settings.telLayout;
            } else {
                settings.layout = settings.keyboardLayout;
            }
        }
        // Keep track of shift status
        var keyboardShift = false;

        // Listen for keypresses
        var pressedKey;
        var onKeypress = function(e) {
            $(this).addClass(settings.btnActiveClasses);
            var keyContent = $(this).attr('data-value' + (keyboardShift ? '-alt' : ''));
            pressedKey = keyContent;
            var parent = $('[aria-describedby=' + $(this).closest('.popover').attr('id') + ']');
            var currentContent = parent.val();
            switch (keyContent) {
                case 'space':
                    currentContent += ' ';
                    break;
                case 'shift':
                    keyboardShift = !keyboardShift;
                    keyboardShiftify();
                    break;
                case 'del':
					if(currentContent !== undefined){
						currentContent = currentContent.substr(0, currentContent.length - 1);
					}
                    break;
                case 'enter':
                	currentContent=="";
                	keyboardShift = false;
                    break;
                default:
                	if(currentContent !== undefined && currentContent.length < settings.maxLength){
						currentContent += keyContent;
                	}
                    keyboardShift = false;
            }
            parent.val(currentContent);
            keyboardShiftify();
            parent.focus();
        };
        $(document).off('touchstart', '.jqbtk-row .btn');
        $(document).on('touchstart', '.jqbtk-row .btn', onKeypress);

        $(document).off('mousedown', '.jqbtk-row .btn');
        $(document).on('mousedown', '.jqbtk-row .btn',function(e){
            onKeypress.bind(this,e)();
            
            var parent = $(this).parent().closest('.popover');
            if(pressedKey === 'enter'){
            	angular.element($('[ng-controller="LoginCtrl"]')).scope().login();
				angular.element($('[ng-controller="LoginCtrl"]')).scope().$apply();
				 //	parent.hide();
	            parent.remove();
//				parent.blur();
//				setTimeout(function(){
//				}, 500);
            }
            e.preventDefault();
        });

        // All those trouble just to prevent clicks on the popover from cancelling the focus

       $(document).off('touchend', '.jqbtk-row .btn');
        $(document).on('touchstart', '.jqbtk-row .btn',function(e){
			$(this).removeClass(settings.btnActiveClasses);
			var parent = $(this).parent().closest('.popover');
            if(pressedKey !== 'enter'){
				parent.focus();
            } else {
            
				angular.element($('[ng-controller="LoginCtrl"]')).scope().login();
				angular.element($('[ng-controller="LoginCtrl"]')).scope().$apply();
				 //	parent.hide();
	            parent.remove();
			
            }
//			e.preventDefault();
        });

 
       
        
        $(document).off('click', '.jqbtk-row .btn');
//        $(document).on('click', '.jqbtk-row .btn',function(e){
//        	console.log("-CLICK")
//			var parent = $('[aria-describedby=' + $(this).closest('.popover').attr('id') + ']');
//            if(pressedKey !== 'enter'){
//				parent.focus();
//            } else {
//				parent.blur();
//            }
////			e.preventDefault();
//        });
        $(document).on('touchend', '.jqbtk-row .btn', function() {
			$(this).removeClass(settings.btnActiveClasses);
			var parent = $('[aria-describedby=' + $(this).closest('.popover').attr('id') + ']');
            if(pressedKey !== 'enter'){
				parent.focus();
            } else {
				parent.blur();
//				angular.element($('[ng-controller="LoginCtrl"]')).scope().login();
//				angular.element($('[ng-controller="LoginCtrl"]')).scope().$apply();
            }
//			e.preventDefault();
        });
        $(document).on('touchend', '.jqbtk-row', function(e) {
			e.preventDefault();
			var parent = $('[aria-describedby=' + $(this).closest('.popover').attr('id') + ']');
//            if(pressedKey !== 'enter'){
			parent.focus();
//            } else {
//				parent.blur();
//            }
        });
        // Update keys according to shift status
        var keyboardShiftify = function() {
            $('.jqbtk-container .btn').each(function() {
                switch ($(this).attr('data-value')) {
                    case 'shift':
                    case 'del':
                    case 'space':
                    case 'enter':
                        break;
                    default:
                        $(this).text($(this).attr('data-value' + (keyboardShift ? '-alt' : '')));
                }
            });
        };
        var container = this.data('container');
        if(container!=undefined)
        {
          container = '#'+container;
          settings.container = container;
          settings.placement = 'in';
          settings.trigger = 'manual';
          $(container).addClass('keyboard-container');
        }
        // Set up a popover on each of the targeted elements
        return this.each(function() {
            $(this).popover({
                content: function() {
                    // Optionally set initial caps
                    if (settings.initCaps && $(this).val().length === 0) {
                        keyboardShift = true;
                    }
                    // Set up container
                    var content = $('<div class="jqbtk-container" tabIndex="-1">');
                    $.each(settings.layout, function() {
                        var line = this;
                        var lineContent = $('<div class="jqbtk-row">');
                        $.each(line, function() {
                            var btn = $(settings.btnTpl).addClass(settings.btnClasses);
                            btn.attr('data-value', this[0]).attr('data-value-alt', this[1]);
                            switch (this[0]) {
                                case 'shift':
                                    btn.addClass('jqbtk-shift').html('<span class="glyphicon glyphicon-arrow-up"></span>');
                                    break;
                                case 'space':
                                    btn.addClass('jqbtk-space').html('&nbsp;');
                                    break;
                                case 'del':
                                    btn.addClass('jqbtk-del').html('<span class="zmdi zmdi-arrow-left"></span>');
                                    break;
                                case 'enter':
//                                    btn.addClass('jqbtk-enter').html('<span class="zmdi zmdi-check"></span>');
                                    btn.addClass('jqbtk-enter').html('OK');
                                    break;
									
                                default:
                                    btn.text(btn.attr('data-value' + (keyboardShift ? '-alt' : '')));
                            }
                            lineContent.append(btn);
                        });
                        content.append(lineContent);
                    });
                    return content;
                },
                html: true,
                placement: settings.placement,
                trigger: settings.trigger,
                container:settings.container,
                viewport: settings.container
            });
            if(settings.trigger == 'manual')
            {
              $(this).popover('show');
            }
        });
    };
}(jQuery));

如何修改插件jQBTK以显示字母数字?

0 个答案:

没有答案