您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

dev_sto.native.js 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621
  1. var NS = {
  2. // set_msg:"update_query"
  3. UPDATE_QUERY:"set_msg",
  4. // UPDATE_QUERY:"update_query",
  5. JOIN_DB:"connect_jdb",
  6. // JOIN_DB:"update_query",
  7. }
  8. function pfnf(o){
  9. return function(resolve, reject){
  10. o.resolve=resolve
  11. o.reject=reject
  12. // clog(arguments)
  13. }
  14. }
  15. var isProxy = Symbol("isProxy")
  16. var tlu = {
  17. object:"",
  18. string:true,
  19. number:true,
  20. undefined:true,
  21. boolean:true,
  22. }
  23. function arr_match(m,o){
  24. var k,v
  25. var r = 0
  26. for ([k,v] of Object.entries(m || {})){
  27. if (o[k] != v.valueOf()){
  28. r += 1
  29. return !r
  30. }
  31. // for ([k,v] in m){
  32. // case
  33. // dlog(k,v)
  34. }
  35. return !r
  36. }
  37. function type_info(o){
  38. try {
  39. var t
  40. var flags = {
  41. leaf:false,
  42. deep_not_prx:false,
  43. prx:false,
  44. isObj:false,
  45. isArr:false,
  46. els:false,
  47. }
  48. t = typeof(o)
  49. flags.t=t
  50. // window?.glob_mx?.flags?.type_info_dbg ? clog("type_info") : 0
  51. if (!(o === null)){
  52. flags.isArr = Array.isArray(o)
  53. flags.isObj = Object.prototype == o.__proto__
  54. }
  55. if (tlu[t] === true || o === null){
  56. flags.leaf = true
  57. } else if (t == "object" && o.__prx){
  58. flags.prx = true
  59. } else if (t == "object" && (flags.isArr || flags.isObj)){
  60. flags.prx = false
  61. flags.deep_not_prx = true
  62. } else {
  63. clog("ELSE")
  64. flags.els = true
  65. }
  66. return flags
  67. // !window?.glob_mx?.flags?.type_info_dbg ? clog("type_info") : 0
  68. } catch (err){
  69. clog("type_info err:",err,{flags,o})
  70. }
  71. // clog(t,flags)
  72. }
  73. function deep_prop_v0(o,p){
  74. try {
  75. var arr = jc(p)
  76. var ret = o
  77. while (arr.length){
  78. // clog("deep_prop",arr,ret)
  79. ret = ret[arr.shift()]
  80. }
  81. // clog("deep_prop ret",ret)
  82. return ret
  83. } catch(err){console.error("DEEP_PROP ERR:",err)}
  84. }
  85. class Proxy_Factory {
  86. constructor(o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""){
  87. this.db = o
  88. this.n = n
  89. this.socket_name = socket_name
  90. this.base_n = base_n
  91. this.full_n = full_n
  92. this.hidden_props = ["add_proxy","_set","walker","walker_start","prxy","_sett","_sett2"]
  93. this._pub_cb =[]
  94. this.__prx = true
  95. this.SymPrx = Symbol("SymPrx")
  96. clog("mx Proxy_Factory")
  97. // clog("pfx",{o,n,that:this})
  98. }
  99. constructor_x(){
  100. // o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""
  101. // this.constructor_m(...arguments)
  102. clog("Proxy_Factory constructor")
  103. Proxy_Factory.prototype.constructor_m.call(this,...arguments)
  104. }
  105. mx1(){
  106. clog(("mx1: Proxy_Factory"))
  107. }
  108. init(o){
  109. // dlog("BP",this,this.baseProp,this.__proto__.baseProp,window.baseProp)
  110. // clog("pfx init",{o,that:this})
  111. this.root = o
  112. }
  113. sync(o){
  114. this.root = jc(o.root)
  115. o._pub_cb.push(this._set_recv.bind(this))
  116. }
  117. get prxy(){
  118. return this
  119. }
  120. _set(o,k,v,prx,a0){
  121. this.obj[k]=prx
  122. }
  123. _sett(o,k,v,prx,a0){
  124. dlog("_SETT",this,arguments)
  125. }
  126. _sett2(o,k,v,prx,a0){
  127. dlog("_SETT2",this,arguments)
  128. }
  129. set_pub(obj, prop, val,receiver){
  130. // dlog("qia_pub",obj, prop, val,receiver)
  131. // dlog("qia_pub2",this.n,obj.__path_arr, prop, jx(val))
  132. this._set_pub(obj.__path_arr, prop, jx(val))
  133. }
  134. // dev_glob.fns.tmp_send
  135. _connect_db(){
  136. /*
  137. dev_glob.fns.tmp_send({
  138. "key":"connect_jdb",
  139. // ,
  140. init_obj:this.db,
  141. "payload":{},
  142. db_id:this.db_conn.db_id,
  143. },this.socket_name)
  144. // */
  145. this._wssto_send({
  146. // "key":"connect_jdb",
  147. "key":NS.JOIN_DB,
  148. // ,
  149. tx:["abc",,2],
  150. init_obj:this.db,
  151. "payload":{},
  152. })
  153. }
  154. get db_conn(){
  155. return {db_id:{n:this.n,base_n:this.base_n,full_n:this.full_n},socket_name:this.socket_name}
  156. }
  157. // _req_sync(){}
  158. _wssto_send(o){
  159. clog("wssto: m0")
  160. if (!o.wssto_key){
  161. o.wssto_key = o.key
  162. o.key = "wssto"
  163. }
  164. // o.key = "_wssto_" + o.key
  165. this.send(o)
  166. }
  167. send(o){
  168. // dev_glob.fns.tmp_send({
  169. glob_vhook.fns.tmp_send({
  170. db_id:this.db_conn.db_id,
  171. ...o,
  172. },this.socket_name)
  173. }
  174. send_raw(){
  175. clog("DBQ")
  176. }
  177. _set_pub(path,key,val){
  178. var k,v
  179. clog("dev_sto","_set_pub")
  180. /*
  181. tmsgx({
  182. "type":"set_msg",
  183. "payload":{path,key,val},
  184. },"code")
  185. // */
  186. //
  187. this._wssto_send({
  188. // "type":"set_msg",
  189. "type":NS.UPDATE_QUERY,
  190. "key":NS.UPDATE_QUERY,
  191. "payload":{path,key,val},
  192. })
  193. /*
  194. dev_glob.fns.tmp_send({
  195. // tmsgx3({
  196. // })
  197. "type":"set_msg",
  198. "key":"set_msg",
  199. db_id:this.db_conn.db_id,
  200. // "payload":{path,key,val,db_id:{n:this.n,base_n:this.base_n}},},this.socket_name
  201. "payload":{path,key,val},},this.socket_name
  202. // window.tmsgx_to || {}
  203. // {to:"nl4qbyiz61z-mce1@specplot.com/FlUkwrLs"},
  204. // {to:"maf@conference.i.specplot.com/0695c1e4"},
  205. // {},
  206. )
  207. */
  208. for (v of this._pub_cb){
  209. v(path,key,val)
  210. }
  211. }
  212. _set_recv(path,prop,val){
  213. // return
  214. var p = path
  215. var nprop = deep_prop_v0(this.root,p)
  216. clog("_set_recv:",nprop)
  217. var dpth = nprop.__dpth
  218. if (tlu[typeof(val)]){
  219. nprop._set(nprop,prop,val,val)
  220. } else {
  221. nprop._set(nprop,prop,val,new Proxy(val,this))
  222. nprop[prop].add_proxy(nprop,prop,val,dpth+1)
  223. }
  224. // var tf = {}
  225. // this.walker(nprop[prop],tf,dpth+2)
  226. this.walker(nprop[prop],{},dpth+2)
  227. }
  228. set(obj, prop, val,receiver){
  229. // dlog("prx_db set ",this,obj, prop, val,receiver,val.__prx)
  230. // clog("prx_db set ",{that:this,obj, prop, val,receiver},val.__prx)
  231. // clog("prx_db set ",obj.__path_arr)
  232. if (obj[prop] === val){
  233. return Reflect.set(...arguments)
  234. }
  235. this.set_pub(obj, prop, val,receiver)
  236. this.event_proc("set")
  237. if ("__prx" == prop){
  238. this.__prx=val
  239. return this.__prx
  240. }
  241. if (typeof(val) === "object" && val != null && !(val.__prx)){
  242. var ret = Reflect.set(...arguments)
  243. this.set_obj(obj, prop, val,receiver)
  244. return ret
  245. }
  246. return Reflect.set(...arguments)
  247. }
  248. get(obj, prop,receiver){
  249. // dlog("prx_db get ...",prop==isProxy,this,obj, prop,receiver)
  250. if (this.hidden_props.includes(prop)){
  251. switch (prop){
  252. case "add_proxy":
  253. return this.add_proxy.bind(this)
  254. break;
  255. case "prxy":
  256. return this
  257. case "_set":
  258. // dlog("_SET")
  259. // return this._set.bind({this})
  260. return this._set.bind({that:this,obj, prop,receiver})
  261. case "_sett":
  262. return this._sett.bind({that:this,obj, prop,receiver})
  263. case "_sett2":
  264. return this._sett2.bind({that:this})
  265. case "walker_start":
  266. return this.walker_start
  267. case "walker":
  268. return this.walker
  269. break;
  270. }
  271. }
  272. if (isProxy == prop){ return true }
  273. if ("__prx" == prop){ return this.__prx }
  274. return Reflect.get(...arguments)
  275. }
  276. add_proxy(o,k,v,dpth){
  277. // clog("~add_proxy~",o,k,v,dpth)
  278. // clog("~add_proxy~",o.__prx,o,k,v,dpth,xpath)
  279. var xpath = o.__path
  280. var apath = o.__path_arr
  281. this.event_proc("add_proxy")
  282. if (!apath){
  283. apath=[]
  284. }
  285. if (!xpath){
  286. xpath="ROOT!"
  287. }
  288. Object.defineProperty(v,"__path_arr",Object.assign({value:apath.concat(k),},this.baseProp))
  289. Object.defineProperty(v,"__path",Object.assign({value:xpath+":"+k,},this.baseProp))
  290. Object.defineProperty(v,"__dpth",Object.assign({value:dpth,},this.baseProp))
  291. // Object.defineProperty(v,"__dbg",Object.assign({value:{},},this.baseProp))
  292. }
  293. set_obj(obj, prop, val,receiver){
  294. var dpth = obj.__dpth
  295. var tf = {}
  296. this.walker(receiver,tf,dpth)
  297. }
  298. walker(o,tfo,dpth=0){
  299. // dlog("qia WALK",this)
  300. if (dpth > 7){
  301. console.error("MAX DEPTH")
  302. return
  303. }
  304. var k,v
  305. var tf
  306. for ([k,v] of Object.entries(o)){
  307. tf = type_info(v)
  308. if (tf.deep_not_prx){
  309. o._set(o,k,v,new Proxy(v,this.prxy))
  310. o[k].add_proxy(o,k,v,dpth)
  311. this.walker(o[k],tf,dpth+1)
  312. }
  313. }
  314. }
  315. walker_start(o,dpth){
  316. var tf = type_info(o)
  317. o.add_proxy({},[],o,-1)
  318. this.walker(o,tf,0)
  319. }
  320. event_proc(e){}
  321. }
  322. var permissions_def = {
  323. participants:{
  324. m:["participants"],
  325. fn(set_scope,match){
  326. // clog("FN....",match.fp,match.fp[1] == window.glob_mx.local_id)
  327. return
  328. /*
  329. if (match.fp[1] != window.glob_mx.local_id)
  330. throw "permission err"
  331. return
  332. */
  333. },
  334. }
  335. }
  336. class Proxy_Permissions extends Proxy_Factory {
  337. // constructor_m(a,a1){
  338. constructor(a,a1){
  339. clog("mx Proxy_Permissions")
  340. super(...arguments)
  341. }
  342. constructor_x(){
  343. // o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""
  344. super.constructor_x(...arguments)
  345. this.constructor_m(...arguments)
  346. // Proxy_Permissions.prototype.constructor_m.call(this,...arguments)
  347. // this.prototype.constructor_m.call(this,...arguments)
  348. }
  349. mx1(){
  350. clog(("mx1: Proxy_Permissions"))
  351. }
  352. set(obj, prop, val,receiver){
  353. // clog("PRX_PERM",obj.__path_arr,prop)
  354. var k,v
  355. var r
  356. var matched
  357. var fp = obj.__path_arr.concat(prop)
  358. for ([k,v] of Object.entries(permissions_def)){
  359. matched = arr_match(v.m,fp)
  360. if (matched){
  361. r = v.fn({that:this,obj, prop, val,receiver},{fp,k,v}) || {}
  362. }
  363. // if (r.return)
  364. }
  365. // case
  366. // if (obj.__path_arr && obj.__path_arr.length){}
  367. return super.set(obj, prop, val,receiver)
  368. }
  369. _set(){
  370. // clog("Proxy_Permissions _set")
  371. super._set(...arguments)
  372. }
  373. }
  374. function splice_out(arr,elm){
  375. let i = arr.indexOf(elm)
  376. // var r = ""
  377. if (i != -1){
  378. return arr.splice(i,1)
  379. }
  380. // return
  381. }
  382. function gen_sort_attr(attr){
  383. return function gsort(a0,a1){
  384. // clog("z",a0,a1)
  385. if (a0[attr] > a1[attr]){
  386. return 1
  387. } else if (a0[attr] < a1[attr]){
  388. return -1
  389. } else {
  390. return 0
  391. }
  392. }
  393. }
  394. function find_attr(elm,indx,arr){
  395. // this.attr
  396. // this.val
  397. // clog("F",{that:this,elm,indx,arr})
  398. // if ( elm[this.attr] == this.val){
  399. if (elm && elm[this.attr] == this.val){
  400. return 1
  401. }
  402. }
  403. var dflt_opts = {
  404. sort_fn:gen_sort_attr("override_level"),
  405. log_level:0,
  406. // ns:"",
  407. }
  408. class BoundObj{
  409. constructor(){
  410. this.init()
  411. }
  412. init(){
  413. let k,v,i,j
  414. for ([k,v] of Object.entries(Object.getOwnPropertyDescriptors(this.__proto__))){
  415. if (k.endsWith("_ub") && typeof(v.value) == "function"){
  416. // clog("UB",k,k.slice(1,-3))
  417. j = v.value.bind(this)
  418. j.meta_str = "bound_fn"
  419. this[k.slice(1,-3)] = j
  420. }
  421. }
  422. }
  423. /*
  424. mx2_ub(){
  425. clog("Mx2")
  426. }
  427. */
  428. }
  429. // class reg_cb_ord{
  430. class reg_cb_ord extends BoundObj{
  431. // con
  432. constructor(opts){
  433. super()
  434. this.opts = Object.assign({},dflt_opts,opts)
  435. this.r = Object.assign(this,dflt_opts,opts)
  436. // this.sort_fn = this.opts
  437. this.cb_sto = {}
  438. this._orig_opts = opts
  439. clog("v2 ",this)
  440. }
  441. _reg_cb_ub(cb,key_name,cb_name,override_level = 100,push=1){
  442. if (typeof(cb) != "function"){
  443. console.error("callback is not a function. setting push=r","\ncb:",cb)
  444. push = "r"
  445. // console.error("callback:",cb," is not a function")
  446. }
  447. // var this.cb_sto = {}
  448. var cb_sort = nop
  449. if (!this.cb_sto[key_name]){
  450. this.cb_sto[key_name] = []
  451. }
  452. // this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name})
  453. // splice_out_ti(this.cb_sto[key_name],this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name}))
  454. // var cbo0= this.cb_sto[key_name].find(glob_td.fn.find_html_cb,{fn_key:cb_name})
  455. // var cbo0= this.cb_sto[key_name].find(find_attr,{fn_key:cb_name})
  456. var cbo0= this.cb_sto[key_name].find(find_attr,{attr:"fn_key",val:cb_name})
  457. // clog(cbo0)
  458. splice_out(this.cb_sto[key_name],cbo0)
  459. // tn2t.arr.
  460. // splice_out_cb
  461. let cb_obj = {
  462. cb,
  463. hkey:key_name,
  464. fn_key:cb_name,
  465. override_level,
  466. }
  467. if (push=="r"){
  468. } else if (push){
  469. this.cb_sto[key_name].push(cb_obj)
  470. } else {
  471. this.cb_sto[key_name].unshift(cb_obj)
  472. }
  473. this.cb_sto[key_name].sort(this.sort_fn)
  474. }
  475. _run_cbs_ub(key,arg_obj){
  476. // if (!key in this.cb_sto){return}
  477. // clog("_run_cbs_ub:",key)
  478. var k,v
  479. var o = {
  480. // html_key:key,cbs:glob_mx.html_cb[key],
  481. }
  482. // dlog("RUN_HOOK_CB??",key,glob_mx.hook_cb[key])
  483. try {
  484. this.opts.log_level ? clog("run_cbs",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key]}) : 0
  485. for ([k,v] of Object.entries(this.cb_sto[key]|| {}) ) {
  486. // dlog("RUN_HOOK_CB:",k)
  487. // clog("run_html_cbs:",k,v)
  488. this.opts.log_level > 1 ? clog("run_cbs_e",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v}) : 0
  489. v.cb(
  490. arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v}
  491. )
  492. // v(o)
  493. }
  494. return {
  495. arg_obj,o,ord_that:{that:this,hkey:key,cbs:this.cb_sto[key],k,v}
  496. }
  497. } catch(err){
  498. console.error("ti_v_cb err:",err)
  499. console.log("ti_v_cb err:",err)
  500. }
  501. }
  502. /* fn1(){
  503. clog("fn1",{that:this,args:[...arguments]})
  504. }*/
  505. }
  506. window.tmp_dev_sto = {
  507. Proxy_Factory,Proxy_Permissions,reg_cb_ord,BoundObj
  508. }
  509. // Proxy_Factory