@tarojs/components-advanced 3.6.0-canary.9 → 3.6.1-alpha.0

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.
Files changed (61) hide show
  1. package/LICENSE +119 -1
  2. package/dist/components/index.d.ts +1 -0
  3. package/dist/components/index.js +2 -0
  4. package/dist/components/index.js.map +1 -0
  5. package/dist/components/virtual-list/constants.d.ts +2 -0
  6. package/dist/components/virtual-list/constants.js +4 -0
  7. package/dist/components/virtual-list/constants.js.map +1 -0
  8. package/dist/components/virtual-list/dom-helpers.d.ts +2 -0
  9. package/dist/components/virtual-list/dom-helpers.js +41 -0
  10. package/dist/components/virtual-list/dom-helpers.js.map +1 -0
  11. package/dist/components/virtual-list/index.d.ts +193 -0
  12. package/dist/components/virtual-list/index.js +6 -0
  13. package/dist/components/virtual-list/index.js.map +1 -0
  14. package/dist/components/virtual-list/list-set.d.ts +27 -0
  15. package/dist/components/virtual-list/list-set.js +183 -0
  16. package/dist/components/virtual-list/list-set.js.map +1 -0
  17. package/dist/components/virtual-list/preset.d.ts +49 -0
  18. package/dist/components/virtual-list/preset.js +135 -0
  19. package/dist/components/virtual-list/preset.js.map +1 -0
  20. package/dist/components/virtual-list/react/index.d.ts +4 -0
  21. package/dist/components/virtual-list/react/index.js +35 -0
  22. package/dist/components/virtual-list/react/index.js.map +1 -0
  23. package/dist/components/virtual-list/react/list.d.ts +44 -0
  24. package/dist/components/virtual-list/react/list.js +399 -0
  25. package/dist/components/virtual-list/react/list.js.map +1 -0
  26. package/dist/components/virtual-list/react/validate.d.ts +4 -0
  27. package/dist/components/virtual-list/react/validate.js +64 -0
  28. package/dist/components/virtual-list/react/validate.js.map +1 -0
  29. package/dist/components/virtual-list/utils.d.ts +13 -0
  30. package/dist/components/virtual-list/utils.js +36 -0
  31. package/dist/components/virtual-list/utils.js.map +1 -0
  32. package/dist/components/virtual-list/vue/index.d.ts +17 -0
  33. package/dist/components/virtual-list/vue/index.js +12 -0
  34. package/dist/components/virtual-list/vue/index.js.map +1 -0
  35. package/dist/components/virtual-list/vue/list.d.ts +120 -0
  36. package/dist/components/virtual-list/vue/list.js +468 -0
  37. package/dist/components/virtual-list/vue/list.js.map +1 -0
  38. package/dist/components/virtual-list/vue/render.d.ts +4 -0
  39. package/dist/components/virtual-list/vue/render.js +18 -0
  40. package/dist/components/virtual-list/vue/render.js.map +1 -0
  41. package/dist/index.d.ts +2 -0
  42. package/dist/index.js +8 -0
  43. package/dist/index.js.map +1 -0
  44. package/dist/utils/convert.d.ts +6 -0
  45. package/dist/utils/convert.js +20 -0
  46. package/dist/utils/convert.js.map +1 -0
  47. package/dist/utils/index.d.ts +4 -0
  48. package/dist/utils/index.js +5 -0
  49. package/dist/utils/index.js.map +1 -0
  50. package/dist/utils/lodash.d.ts +2 -0
  51. package/dist/utils/lodash.js +10 -0
  52. package/dist/utils/lodash.js.map +1 -0
  53. package/dist/utils/math.d.ts +3 -0
  54. package/dist/utils/math.js +15 -0
  55. package/dist/utils/math.js.map +1 -0
  56. package/dist/utils/timer.d.ts +6 -0
  57. package/dist/utils/timer.js +24 -0
  58. package/dist/utils/timer.js.map +1 -0
  59. package/package.json +18 -9
  60. package/typings/global.d.ts +1 -0
  61. package/typings/vue.d.ts +7 -0
@@ -0,0 +1,18 @@
1
+ import { __rest } from 'tslib';
2
+ import { h } from 'vue';
3
+
4
+ function render (componentName, options, children) {
5
+ const { attrs = {}, on = {}, props = {}, slots = {} } = options, el = __rest(options, ["attrs", "on", "props", "slots"]);
6
+ if (process.env.FRAMEWORK === 'vue3') {
7
+ // Events
8
+ Object.keys(on).forEach(key => {
9
+ const name = `on${key.charAt(0).toUpperCase()}${key.slice(1)}`;
10
+ el[name] = on[key];
11
+ });
12
+ return h(componentName, Object.assign(Object.assign(Object.assign(Object.assign({}, attrs), props), slots), el), children);
13
+ }
14
+ return h(componentName, options, children);
15
+ }
16
+
17
+ export { render as default };
18
+ //# sourceMappingURL=render.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"render.js","sources":["../../../../src/components/virtual-list/vue/render.ts"],"sourcesContent":["import { h } from 'vue'\n\nexport default function (componentName: string, options?: Record<string, any>, children?: any) {\n const { attrs = {}, on = {}, props = {}, slots = {}, ...el } = options\n if (process.env.FRAMEWORK === 'vue3') {\n // Events\n Object.keys(on).forEach(key => {\n const name = `on${key.charAt(0).toUpperCase()}${key.slice(1)}`\n el[name] = on[key]\n })\n return h(componentName, { ...attrs, ...props, ...slots, ... el }, children)\n }\n return h(componentName, options, children)\n}\n"],"names":[],"mappings":";;;AAEc,eAAA,EAAW,aAAqB,EAAE,OAA6B,EAAE,QAAc,EAAA;IAC3F,MAAM,EAAE,KAAK,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,KAAK,GAAG,EAAE,EAAE,KAAK,GAAG,EAAE,EAAA,GAAY,OAAO,EAAd,EAAE,GAAA,MAAA,CAAK,OAAO,EAAhE,CAAsD,OAAA,EAAA,IAAA,EAAA,OAAA,EAAA,OAAA,CAAA,CAAU,CAAA;AACtE,IAAA,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,KAAK,MAAM,EAAE;;QAEpC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,IAAG;YAC5B,MAAM,IAAI,GAAG,CAAK,EAAA,EAAA,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA,EAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAA;YAC9D,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AACpB,SAAC,CAAC,CAAA;AACF,QAAA,OAAO,CAAC,CAAC,aAAa,EAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAO,KAAK,CAAK,EAAA,KAAK,CAAK,EAAA,KAAK,CAAM,EAAA,EAAE,CAAI,EAAA,QAAQ,CAAC,CAAA;AAC5E,KAAA;IACD,OAAO,CAAC,CAAC,aAAa,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;AAC5C;;;;"}
@@ -0,0 +1,2 @@
1
+ export * from "./components/index";
2
+ export * from "./utils/index";
package/dist/index.js ADDED
@@ -0,0 +1,8 @@
1
+ import './components/index.js';
2
+ import './utils/index.js';
3
+ export { VirtualList } from './components/virtual-list/index.js';
4
+ export { convertNumber2PX, convertPX2Int } from './utils/convert.js';
5
+ export { omit } from './utils/lodash.js';
6
+ export { getMiddleNumber, isCosDistributing } from './utils/math.js';
7
+ export { cancelTimeout, requestTimeout } from './utils/timer.js';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,6 @@
1
+ /** 将距离值根据单位转换为 Number 类型
2
+ * TODO: 未来可以考虑支持更多单位
3
+ */
4
+ declare function convertPX2Int(distance: string | number): string | number;
5
+ declare function convertNumber2PX(styleValue: unknown): unknown;
6
+ export { convertPX2Int, convertNumber2PX };
@@ -0,0 +1,20 @@
1
+ /** 将距离值根据单位转换为 Number 类型
2
+ * TODO: 未来可以考虑支持更多单位
3
+ */
4
+ function convertPX2Int(distance) {
5
+ if (typeof distance === 'string') {
6
+ const str = distance.toLowerCase();
7
+ if (/px$/.test(str)) {
8
+ return Number(str.replace(/px$/, ''));
9
+ }
10
+ }
11
+ return distance;
12
+ }
13
+ function convertNumber2PX(styleValue) {
14
+ if (!styleValue && styleValue !== 0)
15
+ return '';
16
+ return typeof styleValue === 'number' ? styleValue + 'px' : styleValue;
17
+ }
18
+
19
+ export { convertNumber2PX, convertPX2Int };
20
+ //# sourceMappingURL=convert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"convert.js","sources":["../../src/utils/convert.ts"],"sourcesContent":["/** 将距离值根据单位转换为 Number 类型\n * TODO: 未来可以考虑支持更多单位\n */\nexport function convertPX2Int (distance: string | number) {\n if (typeof distance === 'string') {\n const str = distance.toLowerCase()\n if (/px$/.test(str)) {\n return Number(str.replace(/px$/, ''))\n }\n }\n return distance\n}\n\nexport function convertNumber2PX (styleValue: unknown) {\n if (!styleValue && styleValue !== 0) return ''\n return typeof styleValue === 'number' ? styleValue + 'px' : styleValue\n}\n"],"names":[],"mappings":"AAAA;;AAEG;AACG,SAAU,aAAa,CAAE,QAAyB,EAAA;AACtD,IAAA,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;AAChC,QAAA,MAAM,GAAG,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAA;AAClC,QAAA,IAAI,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YACnB,OAAO,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAA;AACtC,SAAA;AACF,KAAA;AACD,IAAA,OAAO,QAAQ,CAAA;AACjB,CAAC;AAEK,SAAU,gBAAgB,CAAE,UAAmB,EAAA;AACnD,IAAA,IAAI,CAAC,UAAU,IAAI,UAAU,KAAK,CAAC;AAAE,QAAA,OAAO,EAAE,CAAA;AAC9C,IAAA,OAAO,OAAO,UAAU,KAAK,QAAQ,GAAG,UAAU,GAAG,IAAI,GAAG,UAAU,CAAA;AACxE;;;;"}
@@ -0,0 +1,4 @@
1
+ export * from "./convert";
2
+ export * from "./lodash";
3
+ export * from "./math";
4
+ export * from "./timer";
@@ -0,0 +1,5 @@
1
+ export { convertNumber2PX, convertPX2Int } from './convert.js';
2
+ export { omit } from './lodash.js';
3
+ export { getMiddleNumber, isCosDistributing } from './math.js';
4
+ export { cancelTimeout, requestTimeout } from './timer.js';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -0,0 +1,2 @@
1
+ declare function omit<T extends Record<string, unknown> = Record<string, any>, P extends string = ''>(obj?: T, fields?: P[]): Omit<T, P>;
2
+ export { omit };
@@ -0,0 +1,10 @@
1
+ function omit(obj = {}, fields = []) {
2
+ const shallow = Object.assign({}, obj);
3
+ fields.forEach((key) => {
4
+ delete shallow[key];
5
+ });
6
+ return shallow;
7
+ }
8
+
9
+ export { omit };
10
+ //# sourceMappingURL=lodash.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lodash.js","sources":["../../src/utils/lodash.ts"],"sourcesContent":["export function omit<\n T extends Record<string, unknown> = Record<string, any>,\n P extends string = ''\n> (obj: T = ({} as T), fields: P[] = []): Omit<T, P> {\n const shallow = { ...obj }\n fields.forEach((key) => {\n delete shallow[key]\n })\n return shallow\n}\n"],"names":[],"mappings":"SAAgB,IAAI,CAGjB,MAAU,EAAQ,EAAE,SAAc,EAAE,EAAA;AACrC,IAAA,MAAM,OAAO,GAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAQ,GAAG,CAAE,CAAA;AAC1B,IAAA,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,KAAI;AACrB,QAAA,OAAO,OAAO,CAAC,GAAG,CAAC,CAAA;AACrB,KAAC,CAAC,CAAA;AACF,IAAA,OAAO,OAAO,CAAA;AAChB;;;;"}
@@ -0,0 +1,3 @@
1
+ declare function getMiddleNumber(...list: number[]): number;
2
+ declare function isCosDistributing(list: number[], datum?: number): boolean;
3
+ export { getMiddleNumber, isCosDistributing };
@@ -0,0 +1,15 @@
1
+ function getMiddleNumber(...list) {
2
+ return list.sort((a, b) => a - b)[Math.floor(list.length / 2)];
3
+ }
4
+ function isCosDistributing(list, datum = 0) {
5
+ let flags = 0;
6
+ for (let i = 0; i < list.length - 1; i++) {
7
+ if (getMiddleNumber(list[i], datum, list[i + 1]) === datum) {
8
+ flags++;
9
+ }
10
+ }
11
+ return flags === list.length - 1;
12
+ }
13
+
14
+ export { getMiddleNumber, isCosDistributing };
15
+ //# sourceMappingURL=math.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"math.js","sources":["../../src/utils/math.ts"],"sourcesContent":["export function getMiddleNumber (...list: number[]) {\n return list.sort((a, b) => a - b)[Math.floor(list.length / 2)]\n}\n\nexport function isCosDistributing (list: number[], datum = 0) {\n let flags = 0\n for(let i = 0; i < list.length - 1; i++) {\n if (getMiddleNumber(list[i], datum, list[i + 1]) === datum) {\n flags++\n }\n }\n\n return flags === list.length - 1\n}\n"],"names":[],"mappings":"AAAgB,SAAA,eAAe,CAAE,GAAG,IAAc,EAAA;IAChD,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAA;AAChE,CAAC;SAEe,iBAAiB,CAAE,IAAc,EAAE,KAAK,GAAG,CAAC,EAAA;IAC1D,IAAI,KAAK,GAAG,CAAC,CAAA;AACb,IAAA,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;AACvC,QAAA,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,KAAK,EAAE;AAC1D,YAAA,KAAK,EAAE,CAAA;AACR,SAAA;AACF,KAAA;AAED,IAAA,OAAO,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAA;AAClC;;;;"}
@@ -0,0 +1,6 @@
1
+ interface ITimeoutID {
2
+ id: number;
3
+ }
4
+ declare function cancelTimeout(timeoutID: ITimeoutID): void;
5
+ declare function requestTimeout(callback: () => void, delay?: number): ITimeoutID;
6
+ export { cancelTimeout, requestTimeout };
@@ -0,0 +1,24 @@
1
+ import { cancelAnimationFrame, now, requestAnimationFrame } from '@tarojs/runtime';
2
+
3
+ function cancelTimeout(timeoutID) {
4
+ cancelAnimationFrame(timeoutID.id);
5
+ }
6
+ function requestTimeout(callback, delay = 0) {
7
+ const start = now();
8
+ const timeoutID = {
9
+ id: requestAnimationFrame(tick)
10
+ };
11
+ function tick() {
12
+ if (now() - start >= delay) {
13
+ // eslint-disable-next-line no-useless-call
14
+ callback.call(null);
15
+ }
16
+ else {
17
+ timeoutID.id = requestAnimationFrame(tick);
18
+ }
19
+ }
20
+ return timeoutID;
21
+ }
22
+
23
+ export { cancelTimeout, requestTimeout };
24
+ //# sourceMappingURL=timer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timer.js","sources":["../../src/utils/timer.ts"],"sourcesContent":["import { cancelAnimationFrame, now, requestAnimationFrame } from '@tarojs/runtime'\n\ninterface ITimeoutID {\n id: number\n}\n\nexport function cancelTimeout (timeoutID: ITimeoutID) {\n cancelAnimationFrame(timeoutID.id)\n}\n\nexport function requestTimeout (callback: () => void, delay = 0) {\n const start = now()\n\n const timeoutID: ITimeoutID = {\n id: requestAnimationFrame(tick) as number\n }\n\n function tick () {\n if (now() - start >= delay) {\n // eslint-disable-next-line no-useless-call\n callback.call(null)\n } else {\n timeoutID.id = requestAnimationFrame(tick) as number\n }\n }\n\n return timeoutID\n}\n"],"names":[],"mappings":";;AAMM,SAAU,aAAa,CAAE,SAAqB,EAAA;AAClD,IAAA,oBAAoB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;AACpC,CAAC;SAEe,cAAc,CAAE,QAAoB,EAAE,KAAK,GAAG,CAAC,EAAA;AAC7D,IAAA,MAAM,KAAK,GAAG,GAAG,EAAE,CAAA;AAEnB,IAAA,MAAM,SAAS,GAAe;AAC5B,QAAA,EAAE,EAAE,qBAAqB,CAAC,IAAI,CAAW;KAC1C,CAAA;AAED,IAAA,SAAS,IAAI,GAAA;AACX,QAAA,IAAI,GAAG,EAAE,GAAG,KAAK,IAAI,KAAK,EAAE;;AAE1B,YAAA,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACpB,SAAA;AAAM,aAAA;AACL,YAAA,SAAS,CAAC,EAAE,GAAG,qBAAqB,CAAC,IAAI,CAAW,CAAA;AACrD,SAAA;KACF;AAED,IAAA,OAAO,SAAS,CAAA;AAClB;;;;"}
package/package.json CHANGED
@@ -1,11 +1,16 @@
1
1
  {
2
2
  "name": "@tarojs/components-advanced",
3
- "version": "3.6.0-canary.9",
3
+ "version": "3.6.1-alpha.0",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "files": [
8
- "dist"
8
+ "dist",
9
+ "typings"
10
+ ],
11
+ "sideEffects": [
12
+ "*.scss",
13
+ "*.css"
9
14
  ],
10
15
  "keywords": [],
11
16
  "author": "ZakaryCode",
@@ -13,19 +18,24 @@
13
18
  "dependencies": {
14
19
  "memoize-one": "^6.0.0",
15
20
  "postcss": "^8.4.18",
16
- "@tarojs/components": "3.6.0-canary.9",
17
- "@tarojs/shared": "3.6.0-canary.9"
21
+ "@tarojs/components": "3.6.1-alpha.0",
22
+ "@tarojs/shared": "3.6.1-alpha.0"
18
23
  },
19
24
  "devDependencies": {
20
25
  "@babel/cli": "^7.14.5",
21
26
  "@babel/core": "^7.14.5",
22
27
  "@babel/plugin-transform-typescript": "^7.20.2",
28
+ "@rollup/plugin-commonjs": "^20.0.0",
29
+ "@rollup/plugin-node-resolve": "^8.0.0",
23
30
  "@types/node": "^14.14.31",
24
31
  "react": "^18.2.0",
25
32
  "react-dom": "^18.2.0",
33
+ "rollup": "^2.79.0",
34
+ "rollup-plugin-node-externals": "^4.0.0",
35
+ "rollup-plugin-ts": "^3.0.2",
26
36
  "typescript": "^4.7.4",
27
37
  "vue": "^3.0.0",
28
- "babel-preset-taro": "3.6.0-canary.9"
38
+ "babel-preset-taro": "3.6.1-alpha.0"
29
39
  },
30
40
  "peerDependencies": {
31
41
  "react": ">=17"
@@ -39,10 +49,9 @@
39
49
  }
40
50
  },
41
51
  "scripts": {
42
- "build:babel": "cross-env TARO_ENV=h5 babel src --extensions=.js,.jsx,.ts,.tsx --out-dir dist",
43
- "build:declaration": "tsc",
52
+ "prebuild": "pnpm run clean",
53
+ "build": "rollup -c",
44
54
  "clean": "rimraf ./dist",
45
- "dev": "pnpm run build:babel -w",
46
- "prod": "run-s clean build:babel build:declaration"
55
+ "dev": "pnpm run build -w"
47
56
  }
48
57
  }
@@ -0,0 +1 @@
1
+ declare type TFunc = (...args: any[]) => any
@@ -0,0 +1,7 @@
1
+ // Note: 避免 Vue 自定义类型造成全局类型污染,此处使用过 any 替代 App 类型
2
+ export type PluginInstallFunction = (app: any, ...options: any[]) => any
3
+ export type VuePlugin = (PluginInstallFunction & {
4
+ install?: PluginInstallFunction
5
+ }) | {
6
+ install: PluginInstallFunction
7
+ }