funda-ui 4.5.657 → 4.5.671
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ColorPicker/index.js +3 -1
- package/Date/index.d.ts +1 -0
- package/Date/index.js +17 -2
- package/DragDropList/index.css +188 -0
- package/DragDropList/index.d.ts +44 -0
- package/DragDropList/index.js +1587 -0
- package/Input/index.d.ts +2 -0
- package/Input/index.js +14 -1
- package/LICENSE +21 -0
- package/MasonryLayout/index.d.ts +2 -0
- package/MasonryLayout/index.js +115 -5
- package/MultipleSelect/index.css +237 -144
- package/MultipleSelect/index.d.ts +24 -10
- package/MultipleSelect/index.js +2240 -1225
- package/README.md +3 -1
- package/RangeSlider/index.js +14 -1
- package/Textarea/index.d.ts +2 -0
- package/Textarea/index.js +14 -1
- package/Tree/index.d.ts +1 -0
- package/Tree/index.js +29 -0
- package/Utils/useBoundedDrag.d.ts +125 -0
- package/Utils/useBoundedDrag.js +380 -0
- package/Utils/useDragDropPosition.d.ts +169 -0
- package/Utils/useDragDropPosition.js +456 -0
- package/Utils/useIsMobile.d.ts +2 -0
- package/Utils/useIsMobile.js +168 -0
- package/all.d.ts +1 -0
- package/all.js +1 -1
- package/lib/cjs/ColorPicker/index.js +3 -1
- package/lib/cjs/Date/index.d.ts +1 -0
- package/lib/cjs/Date/index.js +17 -2
- package/lib/cjs/DragDropList/index.d.ts +44 -0
- package/lib/cjs/DragDropList/index.js +1587 -0
- package/lib/cjs/Input/index.d.ts +2 -0
- package/lib/cjs/Input/index.js +14 -1
- package/lib/cjs/MasonryLayout/index.d.ts +2 -0
- package/lib/cjs/MasonryLayout/index.js +115 -5
- package/lib/cjs/MultipleSelect/index.d.ts +24 -10
- package/lib/cjs/MultipleSelect/index.js +2240 -1225
- package/lib/cjs/RangeSlider/index.js +14 -1
- package/lib/cjs/Textarea/index.d.ts +2 -0
- package/lib/cjs/Textarea/index.js +14 -1
- package/lib/cjs/Tree/index.d.ts +1 -0
- package/lib/cjs/Tree/index.js +29 -0
- package/lib/cjs/Utils/useBoundedDrag.d.ts +125 -0
- package/lib/cjs/Utils/useBoundedDrag.js +380 -0
- package/lib/cjs/Utils/useDragDropPosition.d.ts +169 -0
- package/lib/cjs/Utils/useDragDropPosition.js +456 -0
- package/lib/cjs/Utils/useIsMobile.d.ts +2 -0
- package/lib/cjs/Utils/useIsMobile.js +168 -0
- package/lib/cjs/index.d.ts +1 -0
- package/lib/cjs/index.js +1 -1
- package/lib/css/DragDropList/index.css +188 -0
- package/lib/css/MultipleSelect/index.css +237 -144
- package/lib/esm/ColorPicker/index.tsx +53 -49
- package/lib/esm/Date/index.tsx +3 -0
- package/lib/esm/DragDropList/index.scss +245 -0
- package/lib/esm/DragDropList/index.tsx +494 -0
- package/lib/esm/Input/index.tsx +17 -3
- package/lib/esm/MasonryLayout/index.tsx +125 -7
- package/lib/esm/MultipleSelect/index.scss +288 -183
- package/lib/esm/MultipleSelect/index.tsx +305 -166
- package/lib/esm/MultipleSelect/utils/func.ts +21 -1
- package/lib/esm/Tabs/Tabs.tsx +1 -1
- package/lib/esm/Textarea/index.tsx +18 -1
- package/lib/esm/Tree/TreeList.tsx +32 -0
- package/lib/esm/Tree/index.tsx +3 -0
- package/lib/esm/Utils/hooks/useBoundedDrag.tsx +301 -0
- package/lib/esm/Utils/hooks/useDragDropPosition.tsx +420 -0
- package/lib/esm/Utils/hooks/useIsMobile.tsx +56 -0
- package/lib/esm/index.js +1 -0
- package/package.json +1 -1
- package/lib/esm/MultipleSelect/ItemList.tsx +0 -323
package/Input/index.d.ts
CHANGED
|
@@ -52,6 +52,8 @@ export declare type InputProps = {
|
|
|
52
52
|
onBlur?: (e: any, param: any, el: any) => void;
|
|
53
53
|
onFocus?: (e: any, param: any, el: any) => void;
|
|
54
54
|
onPressEnter?: (e: any, el: any) => void;
|
|
55
|
+
onKeyDown?: (e: any, el: any) => void;
|
|
56
|
+
onKeyUp?: (e: any, el: any) => void;
|
|
55
57
|
};
|
|
56
58
|
declare const Input: React.ForwardRefExoticComponent<InputProps & React.RefAttributes<unknown>>;
|
|
57
59
|
export default Input;
|
package/Input/index.js
CHANGED
|
@@ -924,7 +924,7 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
924
924
|
/* harmony import */ var funda_utils_dist_cjs_inputsCalculation__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_inputsCalculation__WEBPACK_IMPORTED_MODULE_3__);
|
|
925
925
|
/* harmony import */ var funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(702);
|
|
926
926
|
/* harmony import */ var funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4__);
|
|
927
|
-
var _excluded = ["contentRef", "wrapperClassName", "controlClassName", "controlExClassName", "controlGroupWrapperClassName", "controlGroupTextClassName", "type", "disabled", "required", "placeholder", "pattern", "readOnly", "defaultValue", "value", "requiredLabel", "label", "units", "name", "step", "min", "max", "src", "size", "minLength", "maxLength", "alt", "inputMode", "id", "appendControl", "aiPredict", "aiPredictRemainingTextRGB", "aiPredictConfirmKey", "aiPredictFetchFuncAsync", "aiPredictFetchFuncMethod", "aiPredictFetchFuncMethodParams", "aiPredictFetchCallback", "iconLeft", "iconRight", "autoComplete", "autoCapitalize", "spellCheck", "style", "tabIndex", "onChangeCallback", "onInputCallback", "onKeyPressedCallback", "onChange", "onBlur", "onFocus", "onPressEnter"];
|
|
927
|
+
var _excluded = ["contentRef", "wrapperClassName", "controlClassName", "controlExClassName", "controlGroupWrapperClassName", "controlGroupTextClassName", "type", "disabled", "required", "placeholder", "pattern", "readOnly", "defaultValue", "value", "requiredLabel", "label", "units", "name", "step", "min", "max", "src", "size", "minLength", "maxLength", "alt", "inputMode", "id", "appendControl", "aiPredict", "aiPredictRemainingTextRGB", "aiPredictConfirmKey", "aiPredictFetchFuncAsync", "aiPredictFetchFuncMethod", "aiPredictFetchFuncMethodParams", "aiPredictFetchCallback", "iconLeft", "iconRight", "autoComplete", "autoCapitalize", "spellCheck", "style", "tabIndex", "onChangeCallback", "onInputCallback", "onKeyPressedCallback", "onChange", "onBlur", "onFocus", "onPressEnter", "onKeyDown", "onKeyUp"];
|
|
928
928
|
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) keys.push(key); return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
|
|
929
929
|
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
930
930
|
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
@@ -1001,6 +1001,8 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
|
|
|
1001
1001
|
onBlur = props.onBlur,
|
|
1002
1002
|
onFocus = props.onFocus,
|
|
1003
1003
|
onPressEnter = props.onPressEnter,
|
|
1004
|
+
onKeyDown = props.onKeyDown,
|
|
1005
|
+
onKeyUp = props.onKeyUp,
|
|
1004
1006
|
attributes = _objectWithoutProperties(props, _excluded);
|
|
1005
1007
|
var uniqueID = funda_utils_dist_cjs_useComId__WEBPACK_IMPORTED_MODULE_1___default()();
|
|
1006
1008
|
var idRes = id || uniqueID;
|
|
@@ -1206,6 +1208,12 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
|
|
|
1206
1208
|
set: function set(value, cb) {
|
|
1207
1209
|
setChangedVal("".concat(value));
|
|
1208
1210
|
cb === null || cb === void 0 ? void 0 : cb();
|
|
1211
|
+
},
|
|
1212
|
+
aiPredictReset: function aiPredictReset() {
|
|
1213
|
+
setTimeout(function () {
|
|
1214
|
+
// Avoid conflicts with other asynchronous states, resulting in invalid clearing
|
|
1215
|
+
setCurrentSuggestion('');
|
|
1216
|
+
}, 0);
|
|
1209
1217
|
}
|
|
1210
1218
|
};
|
|
1211
1219
|
}, [contentRef]);
|
|
@@ -1269,6 +1277,7 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
|
|
|
1269
1277
|
}
|
|
1270
1278
|
|
|
1271
1279
|
function handleKeyPressed(event) {
|
|
1280
|
+
onKeyDown === null || onKeyDown === void 0 ? void 0 : onKeyDown(event, valRef.current);
|
|
1272
1281
|
if (typeof onKeyPressedCallback === 'function') {
|
|
1273
1282
|
var newData = onKeyPressedCallback(event, valRef.current);
|
|
1274
1283
|
if (newData) setChangedVal(newData); // Avoid the error "react checkbox changing an uncontrolled input to be controlled"
|
|
@@ -1312,6 +1321,9 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
|
|
|
1312
1321
|
setCurrentSuggestion(tempMatchedSuggestion[currentSuggestionIndex.current] || '');
|
|
1313
1322
|
}
|
|
1314
1323
|
}
|
|
1324
|
+
function handleKeyUp(event) {
|
|
1325
|
+
onKeyUp === null || onKeyUp === void 0 ? void 0 : onKeyUp(event, valRef.current);
|
|
1326
|
+
}
|
|
1315
1327
|
(0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () {
|
|
1316
1328
|
// update default value
|
|
1317
1329
|
//--------------
|
|
@@ -1403,6 +1415,7 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
|
|
|
1403
1415
|
}
|
|
1404
1416
|
},
|
|
1405
1417
|
onKeyDown: handleKeyPressed,
|
|
1418
|
+
onKeyUp: handleKeyUp,
|
|
1406
1419
|
onCompositionStart: handleComposition,
|
|
1407
1420
|
onCompositionUpdate: handleComposition,
|
|
1408
1421
|
onCompositionEnd: handleComposition,
|
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2018 UIUX Lab
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAM AGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/MasonryLayout/index.d.ts
CHANGED
|
@@ -3,10 +3,12 @@ export declare type MasonryLayoutProps = {
|
|
|
3
3
|
columns?: number;
|
|
4
4
|
gap?: number;
|
|
5
5
|
breakPoints?: Record<number, number>;
|
|
6
|
+
balanceColumnHeights?: boolean;
|
|
6
7
|
/** -- */
|
|
7
8
|
id?: string;
|
|
8
9
|
tabIndex?: number;
|
|
9
10
|
children: React.ReactNode;
|
|
11
|
+
onResize?: (wrapperWidth: number) => void;
|
|
10
12
|
};
|
|
11
13
|
declare const MasonryLayout: (props: MasonryLayoutProps) => JSX.Element;
|
|
12
14
|
export default MasonryLayout;
|
package/MasonryLayout/index.js
CHANGED
|
@@ -414,6 +414,10 @@ __webpack_require__.r(__webpack_exports__);
|
|
|
414
414
|
/* harmony import */ var funda_utils_dist_cjs_useComId__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_useComId__WEBPACK_IMPORTED_MODULE_1__);
|
|
415
415
|
/* harmony import */ var funda_utils_dist_cjs_performance__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(840);
|
|
416
416
|
/* harmony import */ var funda_utils_dist_cjs_performance__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_performance__WEBPACK_IMPORTED_MODULE_2__);
|
|
417
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
418
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
419
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
420
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
417
421
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
418
422
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
419
423
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
@@ -427,8 +431,11 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
427
431
|
var columns = props.columns,
|
|
428
432
|
gap = props.gap,
|
|
429
433
|
breakPoints = props.breakPoints,
|
|
434
|
+
_props$balanceColumnH = props.balanceColumnHeights,
|
|
435
|
+
balanceColumnHeights = _props$balanceColumnH === void 0 ? true : _props$balanceColumnH,
|
|
430
436
|
id = props.id,
|
|
431
|
-
children = props.children
|
|
437
|
+
children = props.children,
|
|
438
|
+
onResize = props.onResize;
|
|
432
439
|
var uniqueID = funda_utils_dist_cjs_useComId__WEBPACK_IMPORTED_MODULE_1___default()();
|
|
433
440
|
var idRes = id || uniqueID;
|
|
434
441
|
var rootRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);
|
|
@@ -437,12 +444,19 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
437
444
|
_useState2 = _slicedToArray(_useState, 2),
|
|
438
445
|
items = _useState2[0],
|
|
439
446
|
setItems = _useState2[1];
|
|
447
|
+
var _useState3 = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)([]),
|
|
448
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
449
|
+
orginalItems = _useState4[0],
|
|
450
|
+
setOrginalItems = _useState4[1];
|
|
440
451
|
var COLS = typeof columns !== 'undefined' ? parseFloat(columns) : 2;
|
|
441
452
|
var GAP = typeof gap !== 'undefined' ? parseFloat(gap) : 15;
|
|
453
|
+
var colsRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(new Map());
|
|
442
454
|
var windowResizeUpdate = (0,funda_utils_dist_cjs_performance__WEBPACK_IMPORTED_MODULE_2__.debounce)(handleWindowUpdate, 50);
|
|
443
455
|
var windowWidth = typeof window !== 'undefined' ? window.innerWidth : 0;
|
|
444
456
|
var calcInit = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function (w) {
|
|
445
457
|
var _rootRef$current;
|
|
458
|
+
var minColIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
|
|
459
|
+
var maxColIndex = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : undefined;
|
|
446
460
|
var colCount = COLS;
|
|
447
461
|
var columnWrapper = {};
|
|
448
462
|
var result = [];
|
|
@@ -500,10 +514,22 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
500
514
|
var wrapperWidth = ((_rootRef$current = rootRef.current) === null || _rootRef$current === void 0 ? void 0 : _rootRef$current.offsetWidth) || 0;
|
|
501
515
|
var perBrickWidth = wrapperWidth / colCount; // Prevent the width of the internal elements from overflowing
|
|
502
516
|
|
|
503
|
-
|
|
517
|
+
// return wrapper width
|
|
518
|
+
onResize === null || onResize === void 0 ? void 0 : onResize(wrapperWidth);
|
|
519
|
+
|
|
520
|
+
//
|
|
521
|
+
react__WEBPACK_IMPORTED_MODULE_0___default().Children.forEach(children, function (child, i) {
|
|
522
|
+
if (!child) return;
|
|
504
523
|
var columnIndex = i % colCount;
|
|
524
|
+
var itemRow = Math.floor(i / colCount);
|
|
525
|
+
var itemIndex = itemRow * colCount + columnIndex;
|
|
526
|
+
|
|
527
|
+
//
|
|
505
528
|
columnWrapper["".concat(itemWrapperKey).concat(columnIndex)].push( /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
|
|
506
529
|
key: i,
|
|
530
|
+
"data-row": itemRow,
|
|
531
|
+
"data-col": columnIndex,
|
|
532
|
+
"data-index": itemIndex,
|
|
507
533
|
style: {
|
|
508
534
|
marginBottom: "".concat(GAP, "px")
|
|
509
535
|
}
|
|
@@ -511,13 +537,19 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
511
537
|
style: perBrickWidth > 0 ? {
|
|
512
538
|
width: perBrickWidth + 'px'
|
|
513
539
|
} : undefined
|
|
514
|
-
},
|
|
540
|
+
}, child)));
|
|
515
541
|
});
|
|
516
542
|
|
|
543
|
+
// Add the item to the shortest column
|
|
544
|
+
if (balanceColumnHeights && typeof minColIndex !== 'undefined' && typeof maxColIndex !== 'undefined' && items.length > COLS) {
|
|
545
|
+
var maxColLastElement = columnWrapper["".concat(itemWrapperKey).concat(maxColIndex)].pop();
|
|
546
|
+
columnWrapper["".concat(itemWrapperKey).concat(minColIndex)].push(maxColLastElement);
|
|
547
|
+
}
|
|
548
|
+
|
|
517
549
|
// STEP 5:
|
|
518
550
|
//=================
|
|
519
551
|
// Wrapping the items in each column with a div and pushing it into the result array
|
|
520
|
-
|
|
552
|
+
var _loop = function _loop(_i3) {
|
|
521
553
|
result.push( /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
|
|
522
554
|
key: _i3,
|
|
523
555
|
className: "masonry-item",
|
|
@@ -525,12 +557,31 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
525
557
|
marginLeft: "".concat(_i3 > 0 ? GAP : 0, "px"),
|
|
526
558
|
flex: '0 1 auto'
|
|
527
559
|
}
|
|
528
|
-
},
|
|
560
|
+
}, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
|
|
561
|
+
className: "masonry-item-inner",
|
|
562
|
+
"data-inner-col": _i3,
|
|
563
|
+
ref: function ref(el) {
|
|
564
|
+
if (el) {
|
|
565
|
+
colsRef.current.set("col-".concat(_i3), el);
|
|
566
|
+
} else {
|
|
567
|
+
colsRef.current["delete"]("col-".concat(_i3));
|
|
568
|
+
}
|
|
569
|
+
}
|
|
570
|
+
}, columnWrapper["".concat(itemWrapperKey).concat(_i3)])));
|
|
571
|
+
};
|
|
572
|
+
for (var _i3 = 0; _i3 < colCount; _i3++) {
|
|
573
|
+
_loop(_i3);
|
|
529
574
|
}
|
|
530
575
|
|
|
531
576
|
// STEP 6:
|
|
532
577
|
//=================
|
|
578
|
+
// update items
|
|
533
579
|
setItems(result);
|
|
580
|
+
|
|
581
|
+
// update orginal items
|
|
582
|
+
if (typeof minColIndex === 'undefined' && typeof maxColIndex === 'undefined') {
|
|
583
|
+
setOrginalItems(result);
|
|
584
|
+
}
|
|
534
585
|
}, [children]);
|
|
535
586
|
function handleWindowUpdate() {
|
|
536
587
|
// Check window width has actually changed and it's not just iOS triggering a resize event on scroll
|
|
@@ -542,6 +593,65 @@ var MasonryLayout = function MasonryLayout(props) {
|
|
|
542
593
|
calcInit(windowWidth);
|
|
543
594
|
}
|
|
544
595
|
}
|
|
596
|
+
function adjustPosition() {
|
|
597
|
+
if (rootRef.current === null) return;
|
|
598
|
+
|
|
599
|
+
// Adjust the position of the element
|
|
600
|
+
var initCols = function initCols() {
|
|
601
|
+
var columnHeights = new Array(COLS).fill(0);
|
|
602
|
+
react__WEBPACK_IMPORTED_MODULE_0___default().Children.forEach(items, function (child, i) {
|
|
603
|
+
if (!child) return;
|
|
604
|
+
var columnIndex = i % COLS;
|
|
605
|
+
|
|
606
|
+
// update column height
|
|
607
|
+
var columnInner = colsRef.current.get("col-".concat(columnIndex));
|
|
608
|
+
if (columnInner) {
|
|
609
|
+
var height = columnInner.offsetHeight;
|
|
610
|
+
columnHeights[columnIndex] = height;
|
|
611
|
+
}
|
|
612
|
+
});
|
|
613
|
+
|
|
614
|
+
// Find the shortest height column
|
|
615
|
+
var minHeight = Math.min.apply(Math, _toConsumableArray(columnHeights));
|
|
616
|
+
var maxHeight = Math.max.apply(Math, _toConsumableArray(columnHeights));
|
|
617
|
+
if (minHeight > 0 && maxHeight > 0 && maxHeight / 2 > minHeight) {
|
|
618
|
+
var columnMinHeightIndex = columnHeights.indexOf(minHeight);
|
|
619
|
+
var columnMaxHeightIndex = columnHeights.indexOf(maxHeight);
|
|
620
|
+
calcInit(windowWidth, columnMinHeightIndex, columnMaxHeightIndex);
|
|
621
|
+
}
|
|
622
|
+
};
|
|
623
|
+
var images = rootRef.current.querySelectorAll('img');
|
|
624
|
+
var imagePromises = [];
|
|
625
|
+
images.forEach(function (img) {
|
|
626
|
+
var imgPromise = new Promise(function (resolve, reject) {
|
|
627
|
+
if (img.complete) {
|
|
628
|
+
resolve();
|
|
629
|
+
} else {
|
|
630
|
+
img.onload = function () {
|
|
631
|
+
return resolve();
|
|
632
|
+
};
|
|
633
|
+
img.onerror = function () {
|
|
634
|
+
return resolve();
|
|
635
|
+
};
|
|
636
|
+
}
|
|
637
|
+
});
|
|
638
|
+
imagePromises.push(imgPromise);
|
|
639
|
+
});
|
|
640
|
+
|
|
641
|
+
// Wait for all images to load
|
|
642
|
+
if (images.length > 0) {
|
|
643
|
+
Promise.all(imagePromises).then(function () {
|
|
644
|
+
initCols();
|
|
645
|
+
})["catch"](function (error) {
|
|
646
|
+
console.error(error);
|
|
647
|
+
});
|
|
648
|
+
} else {
|
|
649
|
+
initCols();
|
|
650
|
+
}
|
|
651
|
+
}
|
|
652
|
+
(0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () {
|
|
653
|
+
adjustPosition();
|
|
654
|
+
}, [orginalItems]);
|
|
545
655
|
(0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () {
|
|
546
656
|
// Initialize items
|
|
547
657
|
//--------------
|