24593687c50b8b435fde5df003e96483cff18af3
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

1) (function (factory) {
2) 	if (typeof define === 'function' && define.amd) {
3) 		// AMD. Register as an anonymous module.
4) 		define(['jquery'], factory);
5) 	} else if (typeof module === 'object' && module.exports) {
6) 		// Node/CommonJS
7) 		module.exports = function( root, jQuery ) {
8) 			if ( jQuery === undefined ) {
9) 				// require('jQuery') returns a factory that requires window to
10) 				// build a jQuery instance, we normalize how we use modules
11) 				// that require this pattern but the window provided is a noop
12) 				// if it's defined (how jquery works)
13) 				if ( typeof window !== 'undefined' ) {
14) 					jQuery = require('jquery');
15) 				}
16) 				else {
17) 					jQuery = require('jquery')(root);
18) 				}
19) 			}
20) 			factory(jQuery);
21) 			return jQuery;
22) 		};
23) 	} else {
24) 		// Browser globals
25) 		factory(jQuery);
26) 	}
27) }(function ($) {
28) 	'use strict'
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

29) 	$.fn.numbercontrol = function (methodOrProps) {
jdarwood007 Fixes issues with destroy....

jdarwood007 authored 2 years ago

30) 		if (methodOrProps === 'destory' || (typeof methodOrProps === 'object' && methodOrProps.destroy !== undefined)) {
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

31) 			this.each(function () {
32) 				$(this).parent().children().each(function (index, value) {
33) 					var thisSelector = $(value);
34) 
jdarwood007 Fixes issues with destroy....

jdarwood007 authored 2 years ago

35) 					if (typeof options === 'object' && options.onBeforeDestoryInitialize !== undefined)
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

36) 						options.onBeforeDestoryInitialize(this);
37) 
38) 					if (!thisSelector.is('input'))
39) 						thisSelector.remove();
40) 
jdarwood007 Fixes issues with destroy....

jdarwood007 authored 2 years ago

41) 					if (typeof options === 'object' && options.onAfterDestoryInitialize !== undefined)
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

42) 						options.onAfterDestoryInitialize(this);
43) 				});
44) 
45) 				$(this).parent().removeClass().addClass('numberControlDestoryed');
jdarwood007 Fixes issues with destroy....

jdarwood007 authored 2 years ago

46) 			});
47) 
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

48) 			return this;
49) 		}
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

50) 
51) 		// Allow customizing the options.
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

52) 		var options = {
53) 			debug: false,
54) 			separator: '.',
55) 			type: 'number',
56) 			prependHtml: '<div class="input-group-prepend"><button class="btn btn-decrease btn-outline-secondary px-1"><span class="oi oi-minus" /></button></div>',
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

57) 			appendHtml: '<div class="input-group-append"><button class="btn btn-increase btn-outline-secondary px-1"><span class="oi oi-plus" /></button></div>',
58) 			inputParentCss: 'input-group numberControl',
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

59) 			inputParent: 'div',
60) 			inputCss: 'numberControlInput form-control px-1',
Jeremy D Touchstart and click may ca...

Jeremy D authored 2 years ago

61) 			bindButtonEvents: 'click touchend',
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

62) 			keyboardLanguage: {
63) 				'UP' : '<span class="oi oi-chevron-top" />',
64) 				'DOWN' : '<span class="oi oi-chevron-bottom" />',
65) 				'INVERSE' : '<span class="oi oi-transfer" />',
66) 				'SEP' : '<span class="oi oi-media-record" />',
67) 			},
68) 			keyboardControl: {
69) 			},
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

70) 			buttons: [...Array(10).keys(), 'DELETE', 'CLEAR', 'DONE', 'CANCEL', 'UP', 'DOWN', 'SEP', 'INVERSE']
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

71) 		}
72) 		for (var option in methodOrProps) {
73) 			options[option] = methodOrProps[option]
74) 		}
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

75) 
Jeremy D Handle trailing 0s Trigger...

Jeremy D authored 2 years ago

76) 		// Parse a float with 0s at the end.
77) 		// Reference: https://stackoverflow.com/questions/4868556/how-do-i-stop-parsefloat-from-stripping-zeroes-to-right-of-decimal
78) 		function customParseFloat(number)
79) 		{
80) 			if (isNaN(parseFloat(number)) !== false)
81) 				return number;
82) 
Jeremy D Cleanup the implantation of...

Jeremy D authored 2 years ago

83) 			let str = String(number),
84) 				arr = str.split(options.separator);
Jeremy D Handle trailing 0s Trigger...

Jeremy D authored 2 years ago

85) 
Jeremy D Cleanup the implantation of...

Jeremy D authored 2 years ago

86) 			return parseFloat(str).toFixed(arr.length === 2 ? arr[1].length : 0);
Jeremy D Handle trailing 0s Trigger...

Jeremy D authored 2 years ago

87) 		}
88) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

89) 		function setNewValue(container, value)
90) 		{
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

91) 			if (options.onBeforeSetNewvalue !== undefined)
92) 				options.onBeforeSetNewvalue(this, event, container, value);
93) 
jdarwood007 Fixes issues with destroy....

jdarwood007 authored 2 years ago

94) 			// The Min value was hit with nothing in the container, which could most likely be a blank string that was converted to a int.
95) 			if (Number.MIN_VALUE == parseFloat(value) && $(container).val() == '')
96) 				return false;
97) 
Jeremy D Make a good demo page to sh...

Jeremy D authored 2 years ago

98) 			// No Nans.
99) 			if (options.type !== 'text' && isNaN(value))
100) 				value = 0;
101) 
102) 			if (options.type === 'text')
103) 				$(container).val(value);
104) 			else if (options.type === 'number')
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

105) 				$(container).val(parseInt(value));
Jeremy D Handle trailing 0s Trigger...

Jeremy D authored 2 years ago

106) 			// Handle floats/decmials with 0s at the end.
107) 			else if ((options.disallowTrailingZero === undefined || options.disallowTrailingZero === false) && value[value.length - 1] == 0)
108) 				$(container).val(customParseFloat(value));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

109) 			else
110) 				$(container).val(parseFloat(value));
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

111) 
Jeremy D Handle trailing 0s Trigger...

Jeremy D authored 2 years ago

112) 			// By default, we should trigger a change to the container.
113) 			if (options.ignoreChangeTrigger === undefined || options.ignoreChangeTrigger === false)
114) 				$(container).trigger('change');
115) 
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

116) 			if (options.onAfterSetNewvalue !== undefined)
117) 				options.onAfterSetNewvalue(this, event, container, value);
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

118) 		}
119) 
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

120) 		// https://stackoverflow.com/questions/9553354/how-do-i-get-the-decimal-places-of-a-floating-point-number-in-javascript
121) 		function precision(a)
122) 		{
123) 			if (!isFinite(a))
124) 				return 0;
125) 
126) 			var e = 1, p = 0;
127) 			while (Math.round(a * e) / e !== a)
128) 			{
129) 				e *= 10;
130) 				p++;
131) 			}
132) 
133) 			return parseInt(p);
134) 		}
135) 
136) 		function FindPercision(v, p)
137) 		{
138) 			if (!isFinite(v))
139) 				return 0;
140) 			return parseInt(v).toString().length + p;
141) 		}
142) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

143) 		function findMinMaxValue()
144) 		{
145) 			var testValue;
146) 			for (var i=0; i < arguments.length; i++) {
147) 				testValue = arguments[i];
148) 				if (typeof testValue !== 'undefined' && !isNaN(testValue))
149) 				{
150) 					if (options.type === 'number' && parseInt(testValue) !== null)
151) 						return parseInt(testValue);
152) 					else if (parseFloat(testValue) !== null)
153) 						return parseFloat(testValue);
154) 					continue;
155) 				}
156) 			}
157) 			return 0;
158) 		}
159) 
160) 		// Bind to each input selector
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

161) 		this.each(function () {
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

162) 			if (options.onBeforeInitialized !== undefined)
163) 				options.onBeforeInitialized(this);
164) 
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

165) 			var $base = $(this);
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

166) 
167) 			// Some settings we either can pull in from a options, from standard attributes or defaults.
168) 			var $step = findMinMaxValue(parseFloat(options.step), parseFloat($base.attr('step')), 1);
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

169) 			var $percision = precision($step) + 1;
Jeremy D Make a good demo page to sh...

Jeremy D authored 2 years ago

170) 			var $minValue = findMinMaxValue(options.min, $base.attr('min'), Number.MIN_SAFE_INTEGER);
171) 			var $maxValue = findMinMaxValue(options.max, $base.attr('max'), Number.MAX_SAFE_INTEGER);
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

172) 
173) 			// Build the parent up. 
Jeremy D Fixed a bug where if inputP...

Jeremy D authored 2 years ago

174) 			if (options.inputParent != '' && (!$($base).parent().is('div') || !$($base).parent().hasClass('numberControlDestoryed'))) {
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

175) 				$base.wrap('<' + options.inputParent + '></' + options.inputParent + '>');
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

176) 			}
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

177) 			var $parent = $base.parent(options.parentSelector);
Jeremy D Fixed a bug where if inputP...

Jeremy D authored 2 years ago

178) 			$parent.addClass(options.inputParentCss);
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

179) 
180) 			// Set the base.
181) 			$base.attr('type', options.type);
182) 			$base.addClass(options.inputCss);
183) 
184) 			// Wrap the buttons around.			
185) 			$base.before(options.prependHtml);
186) 			$base.after(options.appendHtml);
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

187) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

188) 			// Add the style to the body to cleanup input controls for number.
189) 			if (options.type == 'number' && !options.DisableNumberSpinStyleFix)
190) 				$('body').append('<style>' +
191) 							'.numberControlInput::-webkit-outer-spin-button,.numberControlInput::-webkit-inner-spin-button {' + 
192) 								'-webkit-appearance: none;' +
193) 							'}</style>'
194) 				);
195) 
196) 			// The decrease event.
197) 			var $decreaseButton = $parent.find('.btn-decrease');
198) 			$decreaseButton.on(options.bindButtonEvents, function (event) {
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

199) 				event.preventDefault();
Jeremy D Touchstart and click may ca...

Jeremy D authored 2 years ago

200) 				event.stopPropagation();
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

201) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

202) 				if (options.onBeforeClickDecrease !== undefined)
203) 					options.onBeforeClickDecrease(this, event);
204) 				if ($base.val() > $minValue)
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

205) 					setNewValue($base, parseFloat(parseFloat($base.val()) - parseFloat($step)).toPrecision(FindPercision($base.val(), $percision)));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

206) 				if (options.onAfterClickDecrease !== undefined)
207) 					options.onAfterClickDecrease(this, event);
208) 				if (options.debug)
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

209) 					console.log('numbercontrl: decreaseButton: Click', event, parseFloat($base.val()), $minValue, parseFloat($step));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

210) 			});
211) 
212) 			// The increase event.
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

213) 			var $increaseButton = $parent.find('.btn-increase');
214) 			$increaseButton.on(options.bindButtonEvents, function (event) {
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

215) 				event.preventDefault();
Jeremy D Touchstart and click may ca...

Jeremy D authored 2 years ago

216) 				event.stopPropagation();
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

217) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

218) 				if (options.onBeforeClickIncrease !== undefined)
219) 					options.onBeforeClickIncrease(this, event);
220) 				if ($base.val() < $maxValue)
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

221) 					setNewValue($base, parseFloat(parseFloat($base.val()) + parseFloat($step)).toPrecision(FindPercision($base.val(), $percision)));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

222) 				if (options.onAfterClickIncrease !== undefined)
223) 					options.onAfterClickIncrease(this, event);
224) 				if (options.debug)
jdarwood007 Fixed a issue with precisio...

jdarwood007 authored 2 years ago

225) 					console.log('numbercontrl: increaseButton: Click', event, parseFloat($base.val()), $maxValue, parseFloat($step));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

226) 			});
227) 
228) 			// The Popup Numberpad
229) 			if (!options.disableVirtualKeyboard)
230) 			{
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

231) 				var $KeyboardLayout;
232) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

233) 				if (options.onBeforeVirtualKeyboardInitalized !== undefined)
234) 					options.onBeforeVirtualKeyboardInitalized(this);
235) 
236) 				$base.on(options.bindButtonEvents, function (event) {
Jeremy D Touchstart and click may ca...

Jeremy D authored 2 years ago

237) 					event.preventDefault();
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

238) 					event.stopPropagation();
239) 
240) 					if (options.onBeforeVirtualKeyboardOpen !== undefined)
241) 						options.onBeforeVirtualKeyboardOpen(this);
242) 
243) 					var $location = options.virtualKeyboardAttachSelector ? $(options.virtualKeyboardAttachSelector) : $base;
244) 
245) 					if (options.keyboardLayout)
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

246) 						$KeyboardLayout = options.keyboardLayout;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

247) 					else
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

248) 						$KeyboardLayout = 
Jeremy D Fixed a bug where if inputP...

Jeremy D authored 2 years ago

249) 							'<div class="modal-dialog modal-dialog-centered m-auto" style="width: 250px;">' +
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

250) 								'<div class="modal-content">' +
251) 									'<table>' +
252) 										'<tr>' +
253) 											'<td colspan="4">{INPUTBOX}</td>' +
254) 										'</tr><tr>' +
255) 											'<td>{7}</td>' +
256) 											'<td>{8}</td>' +
257) 											'<td>{9}</td>' +
258) 											'<td>{DELETE}</td>' +
259) 										'</tr><tr>' +
260) 											'<td>{4}</td>' +
261) 											'<td>{5}</td>' +
262) 											'<td>{6}</td>' +
263) 											'<td>{CLEAR}</td>' +
264) 										'</tr><tr>' +
265) 											'<td>{1}</td>' +
266) 											'<td>{2}</td>' +
267) 											'<td>{3}</td>' +
268) 											'<td>{DONE}</td>' +
269) 										'</tr><tr>' +
270) 											'<td>{UP}</td>' +
271) 											'<td>{0}</td>' +
272) 											'<td>{DOWN}</td>' +
273) 											'<td>{CANCEL}</td>' +
274) 										'</tr>' +
275) 									'</table>' +
276) 								'</div>' +
277) 							'</div>'
278) 						;
279) 
280) 					// Fill out the input.
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

281) 					if (typeof options.keyboardControl['INPUTBOX'] === 'undefined')
Jeremy D Fixed a bug where if inputP...

Jeremy D authored 2 years ago

282) 						options.keyboardControl['INPUTBOX'] = '<input class="numberControlVirtualNumPad numberControlVirtualNumPadINPUT form-control w-100" type="text" readonly value="{VAL}"/>';
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

283) 					$KeyboardLayout = $KeyboardLayout.replace('{INPUTBOX}', options.keyboardControl['INPUTBOX'].replace('{VAL}', $base.val()).toString());
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

284) 
285) 					// Fill out all buttons.
286) 					$.each(options.buttons, function(i, v){
287) 						var LanguageBox = options.keyboardLanguage[v] ? options.keyboardLanguage[v] : v;
288) 
289) 						if (typeof options.keyboardControl[v] === 'undefined')
290) 							options.keyboardControl[v] = '<button class="numberControlVirtualNumPad numberControlVirtualNumPad' + v + ' btn btn-outline-secondary w-100" data-function="' + v + '">{' + v + '_LANG}</button>';
291) 						$KeyboardLayout = $KeyboardLayout.replace('{' + v + '}', options.keyboardControl[v].replace('{' + v + '_LANG}', LanguageBox));
292) 					});
293) 
294) 					// Attach the keyboard to the container.
295) 					$location.after('<div class="numberControlVirtualNumPad modal d-block">' + $KeyboardLayout + '</div>');
296) 					var $VirtualKeyboard = $parent.find('.numberControlVirtualNumPad');
297) 					var $VirtualKeyboardInput = $VirtualKeyboard.find('.numberControlVirtualNumPadINPUT');
298) 
299) 					// Bind the virtual Keyboard action.
300) 					$VirtualKeyboard.find('.numberControlVirtualNumPad').on(options.bindButtonEvents, function(event){						
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

301) 						event.preventDefault();
Jeremy D Touchstart and click may ca...

Jeremy D authored 2 years ago

302) 						event.stopPropagation();
jdarwood007 Destroy the plugin better....

jdarwood007 authored 3 years ago

303) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

304) 						if (options.debug) console.log('numbercontrl: numberControlVirtualNumPad: Click', event, $base.val(), $VirtualKeyboardInput.val().toString(), $(this).attr('data-function'));
305) 
306) 						var thisFunction = $(this).attr('data-function');
307) 
308) 						if (options.onBeforeVirtualKeyboardButton !== undefined)
309) 							options.onBeforeVirtualKeyboardButton(this, event, thisFunction);
310) 
311) 						switch (thisFunction)
312) 						{
313) 							case 'DELETE':
314) 								$VirtualKeyboardInput.val($VirtualKeyboardInput.val().toString().slice(0, -1));
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

315) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

316) 							
317) 							case 'CLEAR':
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

318) 								$VirtualKeyboardInput.val('');
319) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

320) 							
321) 							case 'DONE':
322) 								if ($VirtualKeyboardInput.val() > $maxValue)
323) 									setNewValue($base, $maxValue);
324) 								else if ($VirtualKeyboardInput.val() < $minValue)
325) 									setNewValue($base, $minValue);
326) 								else
327) 									setNewValue($base, $VirtualKeyboardInput.val());
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

328) 								
329) 								$VirtualKeyboard.remove();
330) 								break;
331) 
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

332) 							case 'CANCEL':
333) 								$VirtualKeyboard.remove();
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

334) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

335) 							
336) 							case 'UP':
337) 								if ($VirtualKeyboardInput.val() < $maxValue)
338) 									setNewValue($VirtualKeyboardInput, parseFloat($VirtualKeyboardInput.val()) + parseFloat($step));
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

339) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

340) 							
341) 							case 'DOWN':
342) 								if ($VirtualKeyboardInput.val() > $minValue)
343) 									setNewValue($VirtualKeyboardInput, parseFloat($VirtualKeyboardInput.val()) - parseFloat($step));
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

344) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

345) 
346) 							case 'SEP':
347) 								if ($VirtualKeyboardInput.val().toString().indexOf(options.separator) === -1)
348) 									$VirtualKeyboardInput.val($VirtualKeyboardInput.val().toString() + options.separator);
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

349) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

350) 
351) 							case 'INVERSE':
352) 								setNewValue($VirtualKeyboardInput, parseFloat($VirtualKeyboardInput.val()) * -1);
jdarwood007 Cleanup, enforce style and...

jdarwood007 authored 3 years ago

353) 								break;
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

354) 														
355) 							// Default to assume its numbers.
356) 							default:
357) 								if ($(this).attr('data-custom-function'))
358) 									$(this).attr('data-custom-function')(this, event, thisFunction);
Jeremy D Make a good demo page to sh...

Jeremy D authored 2 years ago

359) 								else if ($VirtualKeyboardInput.val() == '0' || $VirtualKeyboardInput.val() == '0.000')
360) 									setNewValue($VirtualKeyboardInput, $(this).attr('data-function'));
jdarwood007 Initial commit

jdarwood007 authored 3 years ago

361) 								else
362) 									setNewValue($VirtualKeyboardInput, $VirtualKeyboardInput.val().toString() + $(this).attr('data-function'));
363) 						}
364) 
365) 						if (options.onAfterVirtualKeyboardButton !== undefined)
366) 							options.onAfterVirtualKeyboardButton(this, event, thisFunction);
367) 					});
368) 
369) 					if (options.onAfterVirtualKeyboardOpen !== undefined)
370) 						options.onAfterVirtualKeyboardOpen(this);
371) 				});
372) 
373) 				if (options.onAfterVirtualKeyboardInitalized !== undefined)
374) 					options.onAfterVirtualKeyboardInitalized(this);
375) 			}
376) 
377) 			if (options.onAfterInitialized !== undefined)
378) 				options.onAfterInitialized(this);
379) 			if (options.debug) console.log($base.parent());
380) 		});