solid-alive 0.2.1 → 0.2.5

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/dist/index.js CHANGED
@@ -1 +1 @@
1
- import{createComponent as e}from"solid-js/web";import{createStore as t,produce as n}from"solid-js/store";import{createContext as r,on as o,useContext as i,createRoot as a,createComputed as l,createEffect as v,onCleanup as d}from"solid-js";var s=r({elements:{},info:{frozen:!1},setInfo:()=>{},insertElement:()=>{},onDeactivated:()=>{},onActivated:()=>{},removeAliveElements:()=>{},setCurrentComponentId:()=>{},insertCacheCb:()=>{}});function c(r){let[i,a]=t(),[l,v]=t({frozen:!0}),d="",c=new Map,f=new Map,u={onActivated:{},onDeactivated:{}};var m=e=>{var t;if(Reflect.has(i,e)){var n=null===(t=i[e])||void 0===t?void 0:t.subIds;null==n||n.forEach((t=>t!==e&&m(t))),a((t=>{var n,r;return null===(r=(n=t[e]).dispose)||void 0===r||r.call(n),t[e]=null,delete t[e],t}))}},A=e=>{var{caller:t,path:n}=function(){var e=null,t=null;try{throw new Error}catch(a){var n=a.stack.split("\n"),r=n[0].includes("@")?5:6,o=n[r].trim(),i=o.includes("@")?o.split("@"):o.split(" ").slice(1);e=i[0],t=i[1]}return{caller:e,path:t}}(),r=u[e];return(!r[t]||r[t]===n)&&(u[e][t]=n,!0)},h=(e,t)=>{if(!l.frozen&&t&&A(e)){var n={onActivated:c,onDeactivated:f}[e],r=n.get(d)||new Set;r.add(o([],t))&&n.set(d,r)}};return e(s.Provider,{value:{info:l,elements:i,setInfo:v,onActivated:e=>{h("onActivated",e)},onDeactivated:e=>{h("onDeactivated",e)},insertElement:e=>{let t=e.id;a([t],Object.assign(Object.assign({},i[t]),e))},removeAliveElements:e=>{if(e&&Array.isArray(e))for(const t of e)m(t);else for(const e of Object.values(i))m(e.id)},setCurrentComponentId:e=>{d=e},insertCacheCb:e=>{let t=c.get(e),r=f.get(e);c.delete(e),f.delete(e),u.onActivated={},u.onDeactivated={},Reflect.has(i,e)&&a(n((n=>{n[e].onActivated=t,n[e].onDeactivated=r,n[e].loaded=!0})))}},get children(){return r.children}})}let f=new Set([]);function u(e,t,n,r){return function(o){var{info:c,elements:u,setInfo:m,insertElement:A,setCurrentComponentId:h,insertCacheCb:p}=i(s);Reflect.has(u,t)||(m("frozen",!1),h(t),a((i=>{A({id:t,dispose:i,owner:null,component:r?e:null,element:e(o),subIds:Array.isArray(n)?new Set(n):null})})));var E=e=>{var t;if(u[e].isTop)return e;var n=null===(t=Object.values(u).find((t=>{var n;return null===(n=t.subIds)||void 0===n?void 0:n.has(e)})))||void 0===t?void 0:t.id;return n&&(n=E(n)),n||e};return f.has(E(t))||f.clear(),l((()=>{var e;if(!u[t].loaded){let n=null===(e=u[t])||void 0===e?void 0:e.element;for(;"function"==typeof n;)n=n();n instanceof HTMLElement&&p(t)}})),v((()=>{var e;m("frozen",!1),f.has(t)||u[t].loaded&&(f.add(t),m("frozen",!0),null===(e=u[t].onActivated)||void 0===e||e.forEach((e=>e())),m("frozen",!1))})),d((()=>{var e;c.frozen||(m("frozen",!0),null===(e=u[t].onDeactivated)||void 0===e||e.forEach((e=>e())))})),u[t].element}}function m(t){var n=u((()=>t.children),t.id,t.subIds);return e(n,{})}function A(){var{onActivated:e,onDeactivated:t,removeAliveElements:n,setInfo:r}=i(s);return{onActivated:e,onDeactivated:t,removeAliveElements:n,setInfo:r}}function h(e){var{onActivated:t}=A();t(e)}function p(e){var{onDeactivated:t}=A();t(e)}function E(){var{removeAliveElements:e,setInfo:t}=A();return{removeAliveElements:e,aliveFrozen:()=>t("frozen",!0)}}export{m as AliveComponent,c as AliveProvider,u as aliveTransfer,h as onActivated,p as onDeactivated,E as useAlive};
1
+ import{createComponent as e}from"solid-js/web";import{createStore as n,produce as t}from"solid-js/store";import{createContext as o,on as r,useContext as i,createRoot as l,createComputed as a,createEffect as d,onCleanup as s}from"solid-js";var v=o({elements:{},symbolClose:Symbol("close"),info:{frozen:!1,cbOnOff:"off",currComponentId:""},setInfo:()=>{},insertElement:()=>{},onDeactivated:()=>{},onActivated:()=>{},removeAliveElements:()=>{},insertCacheCb:()=>{}});function c(o){let[i,l]=n(),a={frozen:!1,cbOnOff:"off",currComponentId:""},d=Symbol("close"),s=new Map,c=new Map,f={onActivated:{},onDeactivated:{}};var u=e=>{var n;if(Reflect.has(i,e)){var t=null===(n=i[e])||void 0===n?void 0:n.subIds;null==t||t.forEach((n=>n!==e&&u(n))),l({[e]:void 0})}},m=e=>{var{caller:n,path:t}=function(){var e=null,n=null;try{throw new Error}catch(l){var t=l.stack.split("\n"),o=t[0].includes("@")?5:6,r=t[o].trim(),i=r.includes("@")?r.split("@"):r.split(" ").slice(1);e=i[0],n=i[1]}return{caller:e,path:n}}(),o=f[e];return(!o[n]||o[n]===t)&&(f[e][n]=t,!0)},b=(e,n)=>{var{cbOnOff:t,currComponentId:o}=a;if("on"===t&&o!==d&&n&&m(e)){var i={onActivated:s,onDeactivated:c}[e],l=i.get(o)||new Set;l.add(r([],n))&&i.set(o,l)}};return e(v.Provider,{value:{info:a,elements:i,symbolClose:d,setInfo:(e,n)=>{a[e]=n},onActivated:e=>{b("onActivated",e)},onDeactivated:e=>{b("onDeactivated",e)},insertElement:e=>{let n=e.id,t=Object.values(i).find((e=>{var t;return null===(t=e.subIds)||void 0===t?void 0:t.has(n)}));l([n],Object.assign(Object.assign(Object.assign({},i[n]),e),{fatherId:null==t?void 0:t.id}))},removeAliveElements:e=>{if(Array.isArray(e))for(const n of e)u(n);else if(!e)for(const e of Object.values(i))u(e.id)},insertCacheCb:e=>{let n=s.get(e),o=c.get(e);s.delete(e),c.delete(e),f.onActivated={},f.onDeactivated={},Reflect.has(i,e)&&l(t((t=>{t[e].onActivated=n,t[e].onDeactivated=o,t[e].loaded=!0})))}},get children(){return o.children}})}let f=new Set([]);function u(e,n,t){return function(o){var{info:r,elements:c,symbolClose:u,setInfo:m,insertElement:b,insertCacheCb:A}=i(v);Reflect.has(c,n)||l((r=>{m("currComponentId",n),m("cbOnOff","on"),b({id:n,dispose:r,owner:null,element:e(o),subIds:Array.isArray(t)?new Set(t):null})}));var O=e=>{var n=c[e].fatherId;return n?O(n):e};return f.size&&!f.has(O(n))&&f.clear(),a((()=>{var e;!c[n].loaded&&(e=>{var n;let t=null===(n=c[e])||void 0===n?void 0:n.element;for(;"function"==typeof t;)t=t();return!!(t instanceof HTMLElement||Array.isArray(t))&&t})(n)&&(A(n),!(null===(e=c[n].subIds)||void 0===e?void 0:e.size)&&m("currComponentId",u))})),d((()=>{var e,t,o;r.frozen?!(null===(e=c[n].subIds)||void 0===e?void 0:e.size)&&m("frozen",!1):(null===(t=c[n])||void 0===t?void 0:t.loaded)&&(f.add(n),m("cbOnOff","off"),null===(o=c[n].onActivated)||void 0===o||o.forEach((e=>e())),m("cbOnOff","on"))})),s((()=>{var e,t;r.frozen||(m("cbOnOff","off"),null===(t=null===(e=c[n])||void 0===e?void 0:e.onDeactivated)||void 0===t||t.forEach((e=>e())),m("cbOnOff","on"))})),c[n].element}}function m(n){var t=u((()=>n.children),n.id,n.subIds);return e(t,{})}function b(){var{onActivated:e,onDeactivated:n,removeAliveElements:t,setInfo:o}=i(v);return{onActivated:e,onDeactivated:n,removeAliveElements:t,setInfo:o}}function A(e){var{onActivated:n}=b();n(e)}function O(e){var{onDeactivated:n}=b();n(e)}function h(){var{removeAliveElements:e,setInfo:n}=b();return{removeAliveElements:e,aliveFrozen:()=>n("frozen",!0)}}export{m as AliveComponent,c as AliveProvider,u as aliveTransfer,A as onActivated,O as onDeactivated,h as useAlive};
@@ -1,4 +1,4 @@
1
- import { ProveiderProps } from './default';
1
+ import { ProveiderProps } from "./default";
2
2
  /**
3
3
  * @description Alive
4
4
  * @param children jsx.element
@@ -1,8 +1,8 @@
1
1
  import { JSX } from 'solid-js';
2
2
  /**
3
- * @description Alive 组件用的 转换函数
4
- * @param { ()=> JSX.Element } Component,
3
+ * @description Alive 组件用的 转换函数; aliveTransfer(Comp, ‘/home’)
4
+ * @param { ()=> JSX.Element } Component () => JSX.Element
5
5
  * @param { string } id string,自己的id 值,一定要唯一
6
6
  * @param { Array<string> } [subIds] [string,...], 子组件的 id值 可不传,这样默认销毁时不会去干掉子组件,
7
7
  */
8
- export default function aliveTransfer(Component: <T>(props: T) => JSX.Element, id: string, subIds?: Array<string>, saveComponent?: boolean): <T>(props: T) => JSX.Element;
8
+ export default function aliveTransfer(Component: <T>(props: T) => JSX.Element, id: string, subIds?: Array<string>): <T>(props: T) => JSX.Element;
@@ -1,3 +1,3 @@
1
- import { ContextProps } from "./default";
1
+ import { ContextProps } from './default';
2
2
  declare var Context: import("solid-js").Context<ContextProps>;
3
3
  export default Context;
@@ -7,14 +7,15 @@ export interface ProveiderProps {
7
7
  export interface NodeInfo {
8
8
  id: string
9
9
  loaded?: boolean
10
- owner: any,
11
- component?: ((props:any) => JSX.Element) | null
10
+ owner: any
11
+ props?: any
12
+ component?: ((props: any) => JSX.Element) | null
12
13
  element?: JSX.Element | null
13
14
  subIds?: Set<string> | null
14
15
  dispose?: (() => void) | null
15
16
  onActivated?: null | Set<() => void>
16
17
  onDeactivated?: null | Set<() => void>
17
- isTop?: boolean | null
18
+ fatherId?: string
18
19
  }
19
20
 
20
21
  export interface SetElement {
@@ -26,7 +27,9 @@ export interface StoreProps {
26
27
  }
27
28
 
28
29
  export interface IInfo {
29
- frozen: boolean
30
+ frozen: boolean
31
+ cbOnOff: 'on' | 'off'
32
+ currComponentId: string | symbol
30
33
  }
31
34
 
32
35
  export type TSetInfo = <T extends keyof IInfo>(key: T, value: IInfo[T]) => void
@@ -34,13 +37,13 @@ export type TSetInfo = <T extends keyof IInfo>(key: T, value: IInfo[T]) => void
34
37
  export interface ContextProps {
35
38
  elements: StoreProps
36
39
  info: IInfo
40
+ symbolClose: symbol
37
41
  setInfo: TSetInfo
38
42
  insertElement: (d: NodeInfo) => void
39
43
  onActivated: (cb: () => void) => void
40
44
  onDeactivated: (cb: () => void) => void
41
45
  removeAliveElements: (ids?: Array<IAliveElementIds>) => void
42
- setCurrentComponentId: (id: string | symbol) => void
43
- insertCacheCb: (id: string ) => void
46
+ insertCacheCb: (id: string) => void
44
47
  }
45
48
 
46
49
  interface IActive {
@@ -51,4 +54,4 @@ export interface IPrevCall {
51
54
  onDeactivated: IActive
52
55
  }
53
56
 
54
- export type IAliveElementIds = string
57
+ export type IAliveElementIds = string
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "solid-alive",
3
- "version": "0.2.1",
3
+ "version": "0.2.5",
4
4
  "author": "1iuxs",
5
5
  "description": "solid-alive",
6
6
  "type": "module",
@@ -10,10 +10,11 @@
10
10
  - removeAliveElements: 函数, 可传一个参数, 不传就删除所有缓存 :
11
11
  removeAliveElements(['/home'])
12
12
  - aliveForzen: 暂时不响应 路由数据变化, aliveForzen()
13
+
13
14
  - 子父 缓存/删除 问题
14
- - 如果某组件下有子组件,在父的 AliveTransfer中,
15
+ - 如果某组件下有子组件,在父的 aliveTransfer中,
15
16
  第三个参数,为对象 写上子组件的唯一id: {children:['/childrenId','asf',...]}
16
- - 使用见下图, 也可用 -removeAliveElements 删除
17
+ - 使用见下图, 也可用 removeAliveElements 删除
17
18
 
18
19
 
19
20
 
@@ -22,7 +23,7 @@
22
23
  ```jsx
23
24
  import { render } from 'solid-js/web'
24
25
  import App from './App'
25
- import { aliveProvider } from 'solid-alive'
26
+ import { AliveProvider } from 'solid-alive'
26
27
 
27
28
  const root = document.getElementById('root')
28
29
 
@@ -33,7 +34,7 @@ render(() =>
33
34
  , root!)
34
35
  ```
35
36
 
36
- 2 /App.tsx ,在 solid-alive 中 有 AliveTransfer, 参数: JSX , id:string, children?:[string..]
37
+ 2 /App.tsx ,在 solid-alive 中 有 aliveTransfer, 参数: JSX , id:string, children?:[string..]
37
38
  ```jsx
38
39
  import { Route, Router } from '@solidjs/router';
39
40
  import { aliveTransfer } from 'solid-alive';
@@ -48,10 +49,9 @@ import Single from './views/Blog/Single';
48
49
 
49
50
  const HomeTransfer = aliveTransfer(Home, '/')
50
51
  const AboutTransfer = aliveTransfer(About, '/about')
51
- const ShopTransfer = aliveTransfer(Shop, '/shop',['/shopPage'])
52
+ const ShopTransfer = aliveTransfer(Shop, '/shop', ['/shopPage'])
52
53
  const ShopPageTransfer = aliveTransfer(ShopPage, '/shopPage')
53
54
  const BlogTransfer = aliveTransfer(Blog, '/blog', ['contact', 'single'])
54
- const SingleTsf = aliveTransfer(Single,'single')
55
55
 
56
56
  export default function App() {
57
57
  return (
@@ -89,7 +89,6 @@ import { onActivated,onDeactivated,useAlive, AliveComponent } from "solid-alive
89
89
  export default function Single() {
90
90
  const { removeAliveElements,aliveFrozen } = useAlive()
91
91
 
92
- let divRef: Element | undefined = undefined
93
92
  const click = () => {
94
93
  removeAliveElements(['/about']) // delete '/about'; 删除 /about
95
94
  // removeAliveElements() // delete all alive element; 会删除所有缓存的组件
@@ -126,7 +125,7 @@ export default function Single() {
126
125
  /** App.tsx */
127
126
  import { createEffect, lazy, type Component } from 'solid-js'
128
127
  import { Route, Router } from '@solidjs/router'
129
- import { useAlive,AliveTransfer } from "solid-alive"
128
+ import { useAlive, aliveTransfer } from "solid-alive"
130
129
 
131
130
  const modules = import.meta.glob<{ default: Component<any> }>([
132
131
  './views/**/**.tsx',
@@ -171,7 +170,7 @@ const App: Component = () => {
171
170
  <Router>
172
171
  <Route component={Client}>
173
172
  {/* treeData 将 data变成 树结构数据 */}
174
- {transferRouter(treeData(data, 'id', 'parentId'))}
173
+ {transferRouter(treeData(data))}
175
174
  </Route>
176
175
  </Router>
177
176
  )