From 729952fe2aa19cb85f339e0a679979eb362b8abd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=8A=B2=E9=B9=8F?= Date: Thu, 29 Jul 2021 16:29:01 +0800 Subject: [PATCH] js: add h & v scroll bar enable for input --- doric-js/bundle/doric-lib.es5.js | 8 + doric-js/bundle/doric-lib.js | 8 + doric-js/bundle/doric-sandbox.es5.js | 296 +++++++++++++++++++++++---- doric-js/bundle/doric-vm.js | 8 + doric-js/index.d.ts | 2 + doric-js/lib/src/widget/input.d.ts | 2 + doric-js/lib/src/widget/input.js | 8 + doric-js/src/widget/input.ts | 6 + 8 files changed, 297 insertions(+), 41 deletions(-) diff --git a/doric-js/bundle/doric-lib.es5.js b/doric-js/bundle/doric-lib.es5.js index a44d567b..dfd727d7 100644 --- a/doric-js/bundle/doric-lib.es5.js +++ b/doric-js/bundle/doric-lib.es5.js @@ -2960,6 +2960,14 @@ var Input = /** @class */ (function (_super) { Property, __metadata$3("design:type", Function) ], Input.prototype, "onSubmitEditing", void 0); + __decorate$3([ + Property, + __metadata$3("design:type", Boolean) + ], Input.prototype, "enableHorizontalScrollBar", void 0); + __decorate$3([ + Property, + __metadata$3("design:type", Boolean) + ], Input.prototype, "enableVerticalScrollBar", void 0); __decorate$3([ Property, __metadata$3("design:type", Function) diff --git a/doric-js/bundle/doric-lib.js b/doric-js/bundle/doric-lib.js index 99bff96d..24890510 100644 --- a/doric-js/bundle/doric-lib.js +++ b/doric-js/bundle/doric-lib.js @@ -2293,6 +2293,14 @@ __decorate$3([ Property, __metadata$3("design:type", Function) ], Input.prototype, "onSubmitEditing", void 0); +__decorate$3([ + Property, + __metadata$3("design:type", Boolean) +], Input.prototype, "enableHorizontalScrollBar", void 0); +__decorate$3([ + Property, + __metadata$3("design:type", Boolean) +], Input.prototype, "enableVerticalScrollBar", void 0); __decorate$3([ Property, __metadata$3("design:type", Function) diff --git a/doric-js/bundle/doric-sandbox.es5.js b/doric-js/bundle/doric-sandbox.es5.js index 57aa605f..abccaf36 100644 --- a/doric-js/bundle/doric-sandbox.es5.js +++ b/doric-js/bundle/doric-sandbox.es5.js @@ -1677,7 +1677,7 @@ var doric = (function (exports) { var hasOwnProperty = {}.hasOwnProperty; - var has$1 = function hasOwn(it, key) { + var has$1 = Object.hasOwn || function hasOwn(it, key) { return hasOwnProperty.call(toObject(it), key); }; @@ -1764,7 +1764,7 @@ var doric = (function (exports) { var functionToString = Function.toString; - // this helper broken in `3.4.1-3.4.4`, so we can't use `shared` helper + // this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper if (typeof sharedStore.inspectSource != 'function') { sharedStore.inspectSource = function (it) { return functionToString.call(it); @@ -1783,7 +1783,7 @@ var doric = (function (exports) { (module.exports = function (key, value) { return sharedStore[key] || (sharedStore[key] = value !== undefined ? value : {}); })('versions', []).push({ - version: '3.12.1', + version: '3.14.0', mode: 'global', copyright: '© 2021 Denis Pushkarev (zloirock.ru)' }); @@ -1911,12 +1911,12 @@ var doric = (function (exports) { }; var ceil$2 = Math.ceil; - var floor$9 = Math.floor; + var floor$a = Math.floor; // `ToInteger` abstract operation // https://tc39.es/ecma262/#sec-tointeger var toInteger = function (argument) { - return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor$9 : ceil$2)(argument); + return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor$a : ceil$2)(argument); }; var min$9 = Math.min; @@ -2131,8 +2131,10 @@ var doric = (function (exports) { // eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing var nativeSymbol = !!Object.getOwnPropertySymbols && !fails(function () { - return !String(Symbol()) || - // Chrome 38 Symbol has incorrect toString conversion + var symbol = Symbol(); + // Chrome 38 Symbol has incorrect toString conversion + // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances + return !String(symbol) || !(Object(symbol) instanceof Symbol) || // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances !Symbol.sham && engineV8Version && engineV8Version < 41; }); @@ -3286,7 +3288,6 @@ var doric = (function (exports) { var callWithSafeIterationClosing = function (iterator, fn, value, ENTRIES) { try { return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value); - // 7.4.6 IteratorClose(iterator, completion) } catch (error) { iteratorClose(iterator); throw error; @@ -3443,7 +3444,8 @@ var doric = (function (exports) { if (NEW_ITERATOR_PROTOTYPE) { IteratorPrototype$3 = {}; } - // 25.1.2.1.1 %IteratorPrototype%[@@iterator]() + // `%IteratorPrototype%[@@iterator]()` method + // https://tc39.es/ecma262/#sec-%iteratorprototype%-@@iterator if (!has$1(IteratorPrototype$3, ITERATOR$5)) { createNonEnumerableProperty(IteratorPrototype$3, ITERATOR$5, returnThis$2); } @@ -3517,7 +3519,7 @@ var doric = (function (exports) { } } - // fix Array#{values, @@iterator}.name in V8 / FF + // fix Array.prototype.{ values, @@iterator }.name in V8 / FF if (DEFAULT == VALUES && nativeIterator && nativeIterator.name !== VALUES) { INCORRECT_VALUES_NAME = true; defaultIterator = function values() { return nativeIterator.call(this); }; @@ -3814,8 +3816,64 @@ var doric = (function (exports) { } }); + // TODO: use something more complex like timsort? + var floor$9 = Math.floor; + + var mergeSort = function (array, comparefn) { + var length = array.length; + var middle = floor$9(length / 2); + return length < 8 ? insertionSort(array, comparefn) : merge( + mergeSort(array.slice(0, middle), comparefn), + mergeSort(array.slice(middle), comparefn), + comparefn + ); + }; + + var insertionSort = function (array, comparefn) { + var length = array.length; + var i = 1; + var element, j; + + while (i < length) { + j = i; + element = array[i]; + while (j && comparefn(array[j - 1], element) > 0) { + array[j] = array[--j]; + } + if (j !== i++) { array[j] = element; } + } return array; + }; + + var merge = function (left, right, comparefn) { + var llength = left.length; + var rlength = right.length; + var lindex = 0; + var rindex = 0; + var result = []; + + while (lindex < llength || rindex < rlength) { + if (lindex < llength && rindex < rlength) { + result.push(comparefn(left[lindex], right[rindex]) <= 0 ? left[lindex++] : right[rindex++]); + } else { + result.push(lindex < llength ? left[lindex++] : right[rindex++]); + } + } return result; + }; + + var arraySort = mergeSort; + + var firefox = engineUserAgent.match(/firefox\/(\d+)/i); + + var engineFfVersion = !!firefox && +firefox[1]; + + var engineIsIeOrEdge = /MSIE|Trident/.test(engineUserAgent); + + var webkit = engineUserAgent.match(/AppleWebKit\/(\d+)\./); + + var engineWebkitVersion = !!webkit && +webkit[1]; + var test = []; - var nativeSort = test.sort; + var nativeSort$1 = test.sort; // IE8- var FAILS_ON_UNDEFINED = fails(function () { @@ -3828,15 +3886,78 @@ var doric = (function (exports) { // Old WebKit var STRICT_METHOD = arrayMethodIsStrict('sort'); - var FORCED$l = FAILS_ON_UNDEFINED || !FAILS_ON_NULL || !STRICT_METHOD; + var STABLE_SORT$1 = !fails(function () { + // feature detection can be too slow, so check engines versions + if (engineV8Version) { return engineV8Version < 70; } + if (engineFfVersion && engineFfVersion > 3) { return; } + if (engineIsIeOrEdge) { return true; } + if (engineWebkitVersion) { return engineWebkitVersion < 603; } + + var result = ''; + var code, chr, value, index; + + // generate an array with more 512 elements (Chakra and old V8 fails only in this case) + for (code = 65; code < 76; code++) { + chr = String.fromCharCode(code); + + switch (code) { + case 66: case 69: case 70: case 72: value = 3; break; + case 68: case 71: value = 4; break; + default: value = 2; + } + + for (index = 0; index < 47; index++) { + test.push({ k: chr + index, v: value }); + } + } + + test.sort(function (a, b) { return b.v - a.v; }); + + for (index = 0; index < test.length; index++) { + chr = test[index].k.charAt(0); + if (result.charAt(result.length - 1) !== chr) { result += chr; } + } + + return result !== 'DGBEFHACIJK'; + }); + + var FORCED$l = FAILS_ON_UNDEFINED || !FAILS_ON_NULL || !STRICT_METHOD || !STABLE_SORT$1; + + var getSortCompare$1 = function (comparefn) { + return function (x, y) { + if (y === undefined) { return -1; } + if (x === undefined) { return 1; } + if (comparefn !== undefined) { return +comparefn(x, y) || 0; } + return String(x) > String(y) ? 1 : -1; + }; + }; // `Array.prototype.sort` method // https://tc39.es/ecma262/#sec-array.prototype.sort _export({ target: 'Array', proto: true, forced: FORCED$l }, { sort: function sort(comparefn) { - return comparefn === undefined - ? nativeSort.call(toObject(this)) - : nativeSort.call(toObject(this), aFunction(comparefn)); + if (comparefn !== undefined) { aFunction(comparefn); } + + var array = toObject(this); + + if (STABLE_SORT$1) { return comparefn === undefined ? nativeSort$1.call(array) : nativeSort$1.call(array, comparefn); } + + var items = []; + var arrayLength = toLength(array.length); + var itemsLength, index; + + for (index = 0; index < arrayLength; index++) { + if (index in array) { items.push(array[index]); } + } + + items = arraySort(items, getSortCompare$1(comparefn)); + itemsLength = items.length; + index = 0; + + while (index < itemsLength) { array[index] = items[index++]; } + while (index < arrayLength) { delete array[index++]; } + + return array; } }); @@ -4586,6 +4707,8 @@ var doric = (function (exports) { } }); + // `Date.prototype[@@toPrimitive](hint)` method implementation + // https://tc39.es/ecma262/#sec-date.prototype-@@toprimitive var dateToPrimitive = function (hint) { if (hint !== 'string' && hint !== 'number' && hint !== 'default') { throw TypeError('Incorrect hint'); @@ -4968,8 +5091,9 @@ var doric = (function (exports) { }; redefineAll(C.prototype, { - // 23.1.3.1 Map.prototype.clear() - // 23.2.3.2 Set.prototype.clear() + // `{ Map, Set }.prototype.clear()` methods + // https://tc39.es/ecma262/#sec-map.prototype.clear + // https://tc39.es/ecma262/#sec-set.prototype.clear clear: function clear() { var that = this; var state = getInternalState(that); @@ -4985,8 +5109,9 @@ var doric = (function (exports) { if (descriptors) { state.size = 0; } else { that.size = 0; } }, - // 23.1.3.3 Map.prototype.delete(key) - // 23.2.3.4 Set.prototype.delete(value) + // `{ Map, Set }.prototype.delete(key)` methods + // https://tc39.es/ecma262/#sec-map.prototype.delete + // https://tc39.es/ecma262/#sec-set.prototype.delete 'delete': function (key) { var that = this; var state = getInternalState(that); @@ -5004,8 +5129,9 @@ var doric = (function (exports) { else { that.size--; } } return !!entry; }, - // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined) - // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined) + // `{ Map, Set }.prototype.forEach(callbackfn, thisArg = undefined)` methods + // https://tc39.es/ecma262/#sec-map.prototype.foreach + // https://tc39.es/ecma262/#sec-set.prototype.foreach forEach: function forEach(callbackfn /* , that = undefined */) { var state = getInternalState(this); var boundFunction = functionBindContext(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3); @@ -5016,25 +5142,29 @@ var doric = (function (exports) { while (entry && entry.removed) { entry = entry.previous; } } }, - // 23.1.3.7 Map.prototype.has(key) - // 23.2.3.7 Set.prototype.has(value) + // `{ Map, Set}.prototype.has(key)` methods + // https://tc39.es/ecma262/#sec-map.prototype.has + // https://tc39.es/ecma262/#sec-set.prototype.has has: function has(key) { return !!getEntry(this, key); } }); redefineAll(C.prototype, IS_MAP ? { - // 23.1.3.6 Map.prototype.get(key) + // `Map.prototype.get(key)` method + // https://tc39.es/ecma262/#sec-map.prototype.get get: function get(key) { var entry = getEntry(this, key); return entry && entry.value; }, - // 23.1.3.9 Map.prototype.set(key, value) + // `Map.prototype.set(key, value)` method + // https://tc39.es/ecma262/#sec-map.prototype.set set: function set(key, value) { return define(this, key === 0 ? 0 : key, value); } } : { - // 23.2.3.1 Set.prototype.add(value) + // `Set.prototype.add(value)` method + // https://tc39.es/ecma262/#sec-set.prototype.add add: function add(value) { return define(this, value = value === 0 ? 0 : value, value); } @@ -5050,8 +5180,15 @@ var doric = (function (exports) { var ITERATOR_NAME = CONSTRUCTOR_NAME + ' Iterator'; var getInternalCollectionState = internalStateGetterFor$1(CONSTRUCTOR_NAME); var getInternalIteratorState = internalStateGetterFor$1(ITERATOR_NAME); - // add .keys, .values, .entries, [@@iterator] - // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11 + // `{ Map, Set }.prototype.{ keys, values, entries, @@iterator }()` methods + // https://tc39.es/ecma262/#sec-map.prototype.entries + // https://tc39.es/ecma262/#sec-map.prototype.keys + // https://tc39.es/ecma262/#sec-map.prototype.values + // https://tc39.es/ecma262/#sec-map.prototype-@@iterator + // https://tc39.es/ecma262/#sec-set.prototype.entries + // https://tc39.es/ecma262/#sec-set.prototype.keys + // https://tc39.es/ecma262/#sec-set.prototype.values + // https://tc39.es/ecma262/#sec-set.prototype-@@iterator defineIterator(C, CONSTRUCTOR_NAME, function (iterated, kind) { setInternalState$d(this, { type: ITERATOR_NAME, @@ -5078,7 +5215,9 @@ var doric = (function (exports) { return { value: [entry.key, entry.value], done: false }; }, IS_MAP ? 'entries' : 'values', !IS_MAP, true); - // add [@@species], 23.1.2.2, 23.2.2.2 + // `{ Map, Set }.prototype[@@species]` accessors + // https://tc39.es/ecma262/#sec-get-map-@@species + // https://tc39.es/ecma262/#sec-get-set-@@species setSpecies(CONSTRUCTOR_NAME); } }; @@ -5795,6 +5934,9 @@ var doric = (function (exports) { // Forced replacement object prototype accessors methods var objectPrototypeAccessorsForced = !fails(function () { + // This feature detection crashes old WebKit + // https://github.com/zloirock/core-js/issues/232 + if (engineWebkitVersion && engineWebkitVersion < 535) { return; } var key = Math.random(); // In FF throws only define methods // eslint-disable-next-line no-undef, no-useless-call -- required for testing @@ -6320,7 +6462,8 @@ var doric = (function (exports) { this.reject = aFunction(reject); }; - // 25.4.1.5 NewPromiseCapability(C) + // `NewPromiseCapability` abstract operation + // https://tc39.es/ecma262/#sec-newpromisecapability var f = function (C) { return new PromiseCapability(C); }; @@ -7898,6 +8041,7 @@ var doric = (function (exports) { var SUBSTITUTION_SYMBOLS = /\$([$&'`]|\d{1,2}|<[^>]*>)/g; var SUBSTITUTION_SYMBOLS_NO_NAMED = /\$([$&'`]|\d{1,2})/g; + // `GetSubstitution` abstract operation // https://tc39.es/ecma262/#sec-getsubstitution var getSubstitution = function (matched, str, position, captures, namedCaptures, replacement) { var tailPos = position + matched.length; @@ -8320,7 +8464,7 @@ var doric = (function (exports) { var quot = /"/g; - // B.2.3.2.1 CreateHTML(string, tag, attribute, value) + // `CreateHTML` abstract operation // https://tc39.es/ecma262/#sec-createhtml var createHtml = function (string, tag, attribute, value) { var S = String(requireObjectCoercible(string)); @@ -9107,13 +9251,78 @@ var doric = (function (exports) { var aTypedArray$7 = arrayBufferViewCore.aTypedArray; var exportTypedArrayMethod$8 = arrayBufferViewCore.exportTypedArrayMethod; - var $sort = [].sort; + var Uint16Array = global_1.Uint16Array; + var nativeSort = Uint16Array && Uint16Array.prototype.sort; + + // WebKit + var ACCEPT_INCORRECT_ARGUMENTS = !!nativeSort && !fails(function () { + var array = new Uint16Array(2); + array.sort(null); + array.sort({}); + }); + + var STABLE_SORT = !!nativeSort && !fails(function () { + // feature detection can be too slow, so check engines versions + if (engineV8Version) { return engineV8Version < 74; } + if (engineFfVersion) { return engineFfVersion < 67; } + if (engineIsIeOrEdge) { return true; } + if (engineWebkitVersion) { return engineWebkitVersion < 602; } + + var array = new Uint16Array(516); + var expected = Array(516); + var index, mod; + + for (index = 0; index < 516; index++) { + mod = index % 4; + array[index] = 515 - index; + expected[index] = index - 2 * mod + 3; + } + + array.sort(function (a, b) { + return (a / 4 | 0) - (b / 4 | 0); + }); + + for (index = 0; index < 516; index++) { + if (array[index] !== expected[index]) { return true; } + } + }); + + var getSortCompare = function (comparefn) { + return function (x, y) { + if (comparefn !== undefined) { return +comparefn(x, y) || 0; } + // eslint-disable-next-line no-self-compare -- NaN check + if (y !== y) { return -1; } + // eslint-disable-next-line no-self-compare -- NaN check + if (x !== x) { return 1; } + if (x === 0 && y === 0) { return 1 / x > 0 && 1 / y < 0 ? 1 : -1; } + return x > y; + }; + }; // `%TypedArray%.prototype.sort` method // https://tc39.es/ecma262/#sec-%typedarray%.prototype.sort exportTypedArrayMethod$8('sort', function sort(comparefn) { - return $sort.call(aTypedArray$7(this), comparefn); - }); + var array = this; + if (comparefn !== undefined) { aFunction(comparefn); } + if (STABLE_SORT) { return nativeSort.call(array, comparefn); } + + aTypedArray$7(array); + var arrayLength = toLength(array.length); + var items = Array(arrayLength); + var index; + + for (index = 0; index < arrayLength; index++) { + items[index] = array[index]; + } + + items = arraySort(array, getSortCompare(comparefn)); + + for (index = 0; index < arrayLength; index++) { + array[index] = items[index]; + } + + return array; + }, !STABLE_SORT || ACCEPT_INCORRECT_ARGUMENTS); var aTypedArray$6 = arrayBufferViewCore.aTypedArray; var exportTypedArrayMethod$7 = arrayBufferViewCore.exportTypedArrayMethod; @@ -9250,8 +9459,9 @@ var doric = (function (exports) { }; redefineAll(C.prototype, { - // 23.3.3.2 WeakMap.prototype.delete(key) - // 23.4.3.3 WeakSet.prototype.delete(value) + // `{ WeakMap, WeakSet }.prototype.delete(key)` methods + // https://tc39.es/ecma262/#sec-weakmap.prototype.delete + // https://tc39.es/ecma262/#sec-weakset.prototype.delete 'delete': function (key) { var state = getInternalState(this); if (!isObject(key)) { return false; } @@ -9259,8 +9469,9 @@ var doric = (function (exports) { if (data === true) { return uncaughtFrozenStore(state)['delete'](key); } return data && has$1(data, state.id) && delete data[state.id]; }, - // 23.3.3.4 WeakMap.prototype.has(key) - // 23.4.3.4 WeakSet.prototype.has(value) + // `{ WeakMap, WeakSet }.prototype.has(key)` methods + // https://tc39.es/ecma262/#sec-weakmap.prototype.has + // https://tc39.es/ecma262/#sec-weakset.prototype.has has: function has(key) { var state = getInternalState(this); if (!isObject(key)) { return false; } @@ -9271,7 +9482,8 @@ var doric = (function (exports) { }); redefineAll(C.prototype, IS_MAP ? { - // 23.3.3.3 WeakMap.prototype.get(key) + // `WeakMap.prototype.get(key)` method + // https://tc39.es/ecma262/#sec-weakmap.prototype.get get: function get(key) { var state = getInternalState(this); if (isObject(key)) { @@ -9280,12 +9492,14 @@ var doric = (function (exports) { return data ? data[state.id] : undefined; } }, - // 23.3.3.5 WeakMap.prototype.set(key, value) + // `WeakMap.prototype.set(key, value)` method + // https://tc39.es/ecma262/#sec-weakmap.prototype.set set: function set(key, value) { return define(this, key, value); } } : { - // 23.4.3.1 WeakSet.prototype.add(value) + // `WeakSet.prototype.add(value)` method + // https://tc39.es/ecma262/#sec-weakset.prototype.add add: function add(value) { return define(this, value, true); } diff --git a/doric-js/bundle/doric-vm.js b/doric-js/bundle/doric-vm.js index 60fb7580..4b4f798f 100644 --- a/doric-js/bundle/doric-vm.js +++ b/doric-js/bundle/doric-vm.js @@ -3814,6 +3814,14 @@ __decorate$3([ Property, __metadata$3("design:type", Function) ], Input.prototype, "onSubmitEditing", void 0); +__decorate$3([ + Property, + __metadata$3("design:type", Boolean) +], Input.prototype, "enableHorizontalScrollBar", void 0); +__decorate$3([ + Property, + __metadata$3("design:type", Boolean) +], Input.prototype, "enableVerticalScrollBar", void 0); __decorate$3([ Property, __metadata$3("design:type", Function) diff --git a/doric-js/index.d.ts b/doric-js/index.d.ts index 363ab20d..a21c10ff 100644 --- a/doric-js/index.d.ts +++ b/doric-js/index.d.ts @@ -795,6 +795,8 @@ declare module 'doric/lib/src/widget/input' { editable?: boolean; returnKeyType?: ReturnKeyType; onSubmitEditing?: (text: string) => void; + enableHorizontalScrollBar?: boolean; + enableVerticalScrollBar?: boolean; /** * Called before text is changed * @param editing: text already in box diff --git a/doric-js/lib/src/widget/input.d.ts b/doric-js/lib/src/widget/input.d.ts index d800a986..c6b1acf1 100644 --- a/doric-js/lib/src/widget/input.d.ts +++ b/doric-js/lib/src/widget/input.d.ts @@ -28,6 +28,8 @@ export declare class Input extends View { editable?: boolean; returnKeyType?: ReturnKeyType; onSubmitEditing?: (text: string) => void; + enableHorizontalScrollBar?: boolean; + enableVerticalScrollBar?: boolean; /** * Called before text is changed * @param editing: text already in box diff --git a/doric-js/lib/src/widget/input.js b/doric-js/lib/src/widget/input.js index f979bcac..b4c85ef9 100644 --- a/doric-js/lib/src/widget/input.js +++ b/doric-js/lib/src/widget/input.js @@ -123,6 +123,14 @@ __decorate([ Property, __metadata("design:type", Function) ], Input.prototype, "onSubmitEditing", void 0); +__decorate([ + Property, + __metadata("design:type", Boolean) +], Input.prototype, "enableHorizontalScrollBar", void 0); +__decorate([ + Property, + __metadata("design:type", Boolean) +], Input.prototype, "enableVerticalScrollBar", void 0); __decorate([ Property, __metadata("design:type", Function) diff --git a/doric-js/src/widget/input.ts b/doric-js/src/widget/input.ts index 9f2a76bd..a73e11be 100644 --- a/doric-js/src/widget/input.ts +++ b/doric-js/src/widget/input.ts @@ -81,6 +81,12 @@ export class Input extends View { @Property onSubmitEditing?: (text: string) => void + @Property + enableHorizontalScrollBar?: boolean + + @Property + enableVerticalScrollBar?: boolean + /** * Called before text is changed * @param editing: text already in box