Fundation.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. (function() {
  2. var nodeEnv = typeof require !== 'undefined' && typeof process !== 'undefined';
  3. var __module = nodeEnv ? module : {exports:{}};
  4. var __filename = 'preview-scripts/assets/script/frameWork/compment/Fundation.js';
  5. var __require = nodeEnv ? function (request) {
  6. return cc.require(request);
  7. } : function (request) {
  8. return __quick_compile_project__.require(request, __filename);
  9. };
  10. function __define (exports, require, module) {
  11. if (!nodeEnv) {__quick_compile_project__.registerModule(__filename, module);}"use strict";
  12. cc._RF.push(module, 'd6b68Nm4pVPo75JXou2zZ8L', 'Fundation');
  13. // script/frameWork/compment/Fundation.ts
  14. "use strict";
  15. Object.defineProperty(exports, "__esModule", { value: true });
  16. exports.copyToClipboardForWeb = exports.fastRemoveIndex = exports.sortedLastIndex = exports.sortedIndex = exports.insertionSort = exports.onceArgCall = exports.onceCall = exports.MaxValueOf = exports.CreateIntEnum = exports.CreateObjectKeyAsValueMap = void 0;
  17. //#region ******************************** 辅助函数 ********************************
  18. function CreateObjectKeyAsValueMap(obj) {
  19. var keys = Object.keys(obj);
  20. var ret = Object.create(null);
  21. keys.forEach(function (key) {
  22. ret[key] = key;
  23. });
  24. keys = undefined;
  25. return ret;
  26. }
  27. exports.CreateObjectKeyAsValueMap = CreateObjectKeyAsValueMap;
  28. function CreateIntEnum(states, stateVal) {
  29. if (stateVal === void 0) { stateVal = 1; }
  30. var ret = Object.create(null);
  31. states.forEach(function (state) {
  32. ret[state] = stateVal;
  33. stateVal = stateVal + 1;
  34. });
  35. return ret;
  36. }
  37. exports.CreateIntEnum = CreateIntEnum;
  38. function MaxValueOf(intEnum) {
  39. var init = false;
  40. var maxVal = 0;
  41. for (var k in intEnum) {
  42. if (!init) {
  43. maxVal = intEnum[k];
  44. }
  45. else {
  46. maxVal = (intEnum[k] > maxVal) ? intEnum[k] : maxVal;
  47. }
  48. }
  49. return maxVal;
  50. }
  51. exports.MaxValueOf = MaxValueOf;
  52. function onceCall(cb, cnt) {
  53. if (cnt === void 0) { cnt = 1; }
  54. return function () {
  55. if (cnt <= 0) {
  56. return;
  57. }
  58. ;
  59. --cnt;
  60. if (cnt === 0) {
  61. cb();
  62. }
  63. };
  64. }
  65. exports.onceCall = onceCall;
  66. function onceArgCall(cb, cnt) {
  67. return function (p) {
  68. if (cnt <= 0) {
  69. return;
  70. }
  71. ;
  72. --cnt;
  73. if (cnt === 0) {
  74. cb(p);
  75. }
  76. };
  77. }
  78. exports.onceArgCall = onceArgCall;
  79. //#endregion
  80. /**
  81. * 尾插入排序(从小到大)
  82. * @param list
  83. * @param compare
  84. * @returns
  85. */
  86. function insertionSort(list, compare) {
  87. for (var length = list.length, i = 1; i < length; i++) {
  88. var j = void 0, value = list[i];
  89. for (j = i - 1; j >= 0; j--) {
  90. if (compare(list[j], value) <= 0)
  91. break;
  92. list[j + 1] = list[j];
  93. }
  94. list[j + 1] = value;
  95. }
  96. return list;
  97. }
  98. exports.insertionSort = insertionSort;
  99. /**
  100. * 已排好序(从小到大)的数组,获得 value 应该排在哪个位置(有相同值的情况下,排最左边)
  101. * @param list
  102. * @param value
  103. * @param compare
  104. * @returns
  105. */
  106. function sortedIndex(list, value, compare) {
  107. var low = 0, high = list.length;
  108. while (low < high) {
  109. var mid = (low + high) >>> 1;
  110. if (compare(list[mid], value) < 0)
  111. low = mid + 1;
  112. else
  113. high = mid;
  114. }
  115. return low;
  116. }
  117. exports.sortedIndex = sortedIndex;
  118. /**
  119. * 已排好序(从小到大)的数组,获得 value 应该排在哪个位置(有相同值的情况下,排最右边)
  120. * @param list
  121. * @param value
  122. * @param compare
  123. * @returns
  124. */
  125. function sortedLastIndex(list, value, compare) {
  126. var low = 0, high = list.length;
  127. while (low < high) {
  128. var mid = (low + high) >>> 1;
  129. if (compare(list[mid], value) <= 0)
  130. low = mid + 1;
  131. else
  132. high = mid;
  133. }
  134. return high;
  135. }
  136. exports.sortedLastIndex = sortedLastIndex;
  137. /**
  138. * 快速删除数组元素(不保证删除后的顺序)
  139. * @param arr
  140. * @param idx
  141. */
  142. function fastRemoveIndex(arr, idx) {
  143. if (idx >= 0 && idx < arr.length) {
  144. arr[idx] = arr[arr.length - 1];
  145. arr.length--;
  146. }
  147. }
  148. exports.fastRemoveIndex = fastRemoveIndex;
  149. /**
  150. * 拷贝内容到剪切板
  151. * @param copyStr 内容
  152. */
  153. function copyToClipboardForWeb(copyStr, callback) {
  154. var el = document.createElement('textarea');
  155. el.value = copyStr;
  156. // Prevent keyboard from showing on mobile
  157. el.setAttribute('readonly', '');
  158. //el.style.contain = 'strict';
  159. el.style.position = 'absolute';
  160. el.style.left = '-9999px';
  161. el.style.fontSize = '12pt'; // Prevent zooming on iOS
  162. var selection = getSelection();
  163. var originalRange;
  164. if (selection.rangeCount > 0) {
  165. originalRange = selection.getRangeAt(0);
  166. }
  167. document.body.appendChild(el);
  168. el.select();
  169. // Explicit selection workaround for iOS
  170. el.selectionStart = 0;
  171. el.selectionEnd = copyStr.length;
  172. var isSuccess = false;
  173. try {
  174. isSuccess = document.execCommand('copy');
  175. }
  176. catch (err) {
  177. isSuccess = false;
  178. }
  179. finally {
  180. document.body.removeChild(el);
  181. if (originalRange) {
  182. selection.removeAllRanges();
  183. selection.addRange(originalRange);
  184. }
  185. }
  186. /** 返回结果 */
  187. if (isSuccess) {
  188. callback();
  189. }
  190. else {
  191. callback(new Error("执行剪切板拷贝命令出错"));
  192. }
  193. }
  194. exports.copyToClipboardForWeb = copyToClipboardForWeb;
  195. cc._RF.pop();
  196. }
  197. if (nodeEnv) {
  198. __define(__module.exports, __require, __module);
  199. }
  200. else {
  201. __quick_compile_project__.registerModuleFunc(__filename, function () {
  202. __define(__module.exports, __require, __module);
  203. });
  204. }
  205. })();
  206. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["assets/script/frameWork/compment/Fundation.ts"],"names":[],"mappings":"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","file":"","sourceRoot":"/","sourcesContent":["\n\n//#region ******************************** 类型声明 ********************************\nexport type Callback<T = any> = (err: Error | null, data: T) => void;\nexport type Constructor<T = unknown> = new (...args: any[]) => T;\nexport type ObjectKeyAsValue<T> = { readonly [K in keyof T]: K; }\nexport type KeyArrayAsValue<T extends string> = { readonly [V in T]: V; }\n//#endregion\n\n/**\n * 销毁接口\n */\nexport interface IDispose {\n    Dispose(): void;\n}\n\n/** 自动销毁附着对象 */\nexport interface IDisposeAttachTarget {\n    AutoDispose(toDispose: IDispose): void;\n}\n\n//#region ******************************** 辅助函数 ********************************\nexport function CreateObjectKeyAsValueMap<T extends Object>(obj: T): ObjectKeyAsValue<T> {\n    let keys = Object.keys(obj);\n    let ret: ObjectKeyAsValue<T> = Object.create(null);\n    keys.forEach(key => {\n        ret[key] = key;\n    })\n    keys = undefined;\n    return ret;\n}\n\nexport function CreateIntEnum<T extends string>(states: Array<T>, stateVal: number = 1): { [V in T]: number } {\n    let ret = Object.create(null);\n    states.forEach(state => {\n        ret[state] = stateVal;\n        stateVal = stateVal + 1;\n    })\n    return ret;\n}\n\n\n\nexport function MaxValueOf<T extends string>(intEnum: { [k: string]: number }) {\n    let init = false;\n    let maxVal = 0;\n    for (let k in intEnum) {\n        if (!init) {\n            maxVal = intEnum[k];\n        } else {\n            maxVal = (intEnum[k] > maxVal) ? intEnum[k] : maxVal;\n        }\n    }\n    return maxVal;\n}\n\nexport function onceCall(cb: () => void, cnt: number = 1) {\n    return () => {\n        if (cnt <= 0) {\n            return;\n        };\n        --cnt;\n        if (cnt === 0) {\n            cb()\n        }\n    };\n}\n\nexport function onceArgCall<T>(cb: (p: T) => void, cnt: number) {\n    return (p: T) => {\n        if (cnt <= 0) {\n            return;\n        };\n        --cnt;\n        if (cnt === 0) {\n            cb(p)\n        }\n    }\n}\n//#endregion\n\n/**\n * 尾插入排序（从小到大）\n * @param list \n * @param compare \n * @returns \n */\nexport function insertionSort<T>(list: T[], compare: (a: T, b: T) => number) {\n    for (let length = list.length, i = 1; i < length; i++) {\n        let j, value: T = list[i]\n        for (j = i - 1; j >= 0; j--) {\n            if (compare(list[j], value) <= 0) break\n            list[j + 1] = list[j]\n        }\n        list[j + 1] = value\n    }\n    return list\n}\n\n/**\n * 已排好序(从小到大)的数组，获得 value 应该排在哪个位置（有相同值的情况下，排最左边）\n * @param list \n * @param value \n * @param compare \n * @returns \n */\nexport function sortedIndex<T, V>(list: T[], value: V, compare: (a: T, b: V) => number): number {\n    let low = 0, high = list.length\n    while (low < high) {\n        let mid = (low + high) >>> 1\n        if (compare(list[mid], value) < 0) low = mid + 1\n        else high = mid\n    }\n    return low\n}\n\n/**\n * 已排好序(从小到大)的数组，获得 value 应该排在哪个位置（有相同值的情况下，排最右边）\n * @param list \n * @param value \n * @param compare \n * @returns \n */\nexport function sortedLastIndex<T>(list: T[], value: T, compare: (a: T, b: T) => number): number {\n    let low = 0, high = list.length\n    while (low < high) {\n        let mid = (low + high) >>> 1\n        if (compare(list[mid], value) <= 0) low = mid + 1\n        else high = mid\n    }\n    return high\n}\n\n/**\n * 快速删除数组元素（不保证删除后的顺序）\n * @param arr \n * @param idx \n */\nexport function fastRemoveIndex(arr: any[], idx: number) {\n    if (idx >= 0 && idx < arr.length) {\n        arr[idx] = arr[arr.length - 1];\n        arr.length--;\n    }\n}\n\n/**\n * 拷贝内容到剪切板\n * @param copyStr 内容\n */\nexport function copyToClipboardForWeb(copyStr: string, callback: (err?: Error) => void): void {\n    const el = document.createElement('textarea');\n    el.value = copyStr;\n\n    // Prevent keyboard from showing on mobile\n    el.setAttribute('readonly', '');\n    //el.style.contain = 'strict';\n    el.style.position = 'absolute';\n    el.style.left = '-9999px';\n    el.style.fontSize = '12pt'; // Prevent zooming on iOS\n\n    const selection = getSelection()!;\n    let originalRange;\n    if (selection.rangeCount > 0) {\n        originalRange = selection.getRangeAt(0);\n    }\n\n    document.body.appendChild(el);\n    el.select();\n\n    // Explicit selection workaround for iOS\n    el.selectionStart = 0;\n    el.selectionEnd = copyStr.length;\n\n    let isSuccess = false;\n    try {\n        isSuccess = document.execCommand('copy');\n    } catch (err) {\n        isSuccess = false;\n    } finally {\n        document.body.removeChild(el);\n        if (originalRange) {\n            selection.removeAllRanges();\n            selection.addRange(originalRange);\n        }\n    }\n\n    /** 返回结果 */\n    if (isSuccess) {\n        callback();\n    } else {\n        callback(new Error(\"执行剪切板拷贝命令出错\"))\n    }\n}"]}