Trapped-Frontend.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641
  1. smalltalk.addPackage('Trapped-Frontend', {});
  2. smalltalk.addClass('TrappedDumbView', smalltalk.Widget, [], 'Trapped-Frontend');
  3. smalltalk.TrappedDumbView.comment="I just read and show an actual path."
  4. smalltalk.addMethod(
  5. "_renderOn_",
  6. smalltalk.method({
  7. selector: "renderOn:",
  8. category: 'rendering',
  9. fn: function (html){
  10. var self=this;
  11. smalltalk.send(smalltalk.send(html,"_root",[]),"_trapShow_",[[]]);
  12. return self},
  13. args: ["html"],
  14. source: "renderOn: html\x0a\x09html root trapShow: #()",
  15. messageSends: ["trapShow:", "root"],
  16. referencedClasses: []
  17. }),
  18. smalltalk.TrappedDumbView);
  19. smalltalk.addClass('TrappedModelWrapper', smalltalk.Object, ['dispatcher', 'payload'], 'Trapped-Frontend');
  20. smalltalk.TrappedModelWrapper.comment="I am base class for model wrappers.\x0aI wrap a model which can be any object.\x0a\x0aMy subclasses need to provide implementation for:\x0a\x09read:do:\x0a modify:do:\x0a\x09(optionally) name\x0a\x0aand must initialize:\x0a\x09payload\x0a\x09dispatcher\x0a"
  21. smalltalk.addMethod(
  22. "_dispatcher",
  23. smalltalk.method({
  24. selector: "dispatcher",
  25. category: 'accessing',
  26. fn: function (){
  27. var self=this;
  28. return self["@dispatcher"];
  29. },
  30. args: [],
  31. source: "dispatcher\x0a\x09^dispatcher",
  32. messageSends: [],
  33. referencedClasses: []
  34. }),
  35. smalltalk.TrappedModelWrapper);
  36. smalltalk.addMethod(
  37. "_dispatcher_",
  38. smalltalk.method({
  39. selector: "dispatcher:",
  40. category: 'accessing',
  41. fn: function (aDispatcher){
  42. var self=this;
  43. self["@dispatcher"]=aDispatcher;
  44. return self},
  45. args: ["aDispatcher"],
  46. source: "dispatcher: aDispatcher\x0a\x09dispatcher := aDispatcher",
  47. messageSends: [],
  48. referencedClasses: []
  49. }),
  50. smalltalk.TrappedModelWrapper);
  51. smalltalk.addMethod(
  52. "_name",
  53. smalltalk.method({
  54. selector: "name",
  55. category: 'accessing',
  56. fn: function (){
  57. var self=this;
  58. var $1;
  59. $1=smalltalk.send(smalltalk.send(self,"_class",[]),"_name",[]);
  60. return $1;
  61. },
  62. args: [],
  63. source: "name\x0a\x09^ self class name",
  64. messageSends: ["name", "class"],
  65. referencedClasses: []
  66. }),
  67. smalltalk.TrappedModelWrapper);
  68. smalltalk.addMethod(
  69. "_payload",
  70. smalltalk.method({
  71. selector: "payload",
  72. category: 'accessing',
  73. fn: function (){
  74. var self=this;
  75. return self["@payload"];
  76. },
  77. args: [],
  78. source: "payload\x0a\x09^payload",
  79. messageSends: [],
  80. referencedClasses: []
  81. }),
  82. smalltalk.TrappedModelWrapper);
  83. smalltalk.addMethod(
  84. "_payload_",
  85. smalltalk.method({
  86. selector: "payload:",
  87. category: 'accessing',
  88. fn: function (anObject){
  89. var self=this;
  90. self["@payload"]=anObject;
  91. smalltalk.send(smalltalk.send(self,"_dispatcher",[]),"_changed_",[[]]);
  92. return self},
  93. args: ["anObject"],
  94. source: "payload: anObject\x0a\x09payload := anObject.\x0a self dispatcher changed: #()",
  95. messageSends: ["changed:", "dispatcher"],
  96. referencedClasses: []
  97. }),
  98. smalltalk.TrappedModelWrapper);
  99. smalltalk.addMethod(
  100. "_start",
  101. smalltalk.method({
  102. selector: "start",
  103. category: 'action',
  104. fn: function (){
  105. var self=this;
  106. smalltalk.send(smalltalk.send((smalltalk.Trapped || Trapped),"_current",[]),"_register_name_",[self,smalltalk.send(self,"_name",[])]);
  107. return self},
  108. args: [],
  109. source: "start\x0a\x09Trapped current register: self name: self name",
  110. messageSends: ["register:name:", "name", "current"],
  111. referencedClasses: ["Trapped"]
  112. }),
  113. smalltalk.TrappedModelWrapper);
  114. smalltalk.addMethod(
  115. "_watch_do_",
  116. smalltalk.method({
  117. selector: "watch:do:",
  118. category: 'action',
  119. fn: function (path,aBlock){
  120. var self=this;
  121. smalltalk.send(smalltalk.send(self,"_dispatcher",[]),"_on_hook_",[path,(function(){
  122. return smalltalk.send(self,"_read_do_",[path,aBlock]);
  123. })]);
  124. return self},
  125. args: ["path", "aBlock"],
  126. source: "watch: path do: aBlock\x0a\x09self dispatcher on: path hook: [ self read: path do: aBlock ]\x0a",
  127. messageSends: ["on:hook:", "read:do:", "dispatcher"],
  128. referencedClasses: []
  129. }),
  130. smalltalk.TrappedModelWrapper);
  131. smalltalk.addMethod(
  132. "_start",
  133. smalltalk.method({
  134. selector: "start",
  135. category: 'action',
  136. fn: function (){
  137. var self=this;
  138. var $2,$3,$1;
  139. $2=smalltalk.send(self,"_new",[]);
  140. smalltalk.send($2,"_start",[]);
  141. $3=smalltalk.send($2,"_yourself",[]);
  142. $1=$3;
  143. return $1;
  144. },
  145. args: [],
  146. source: "start\x0a\x09^self new start; yourself",
  147. messageSends: ["start", "new", "yourself"],
  148. referencedClasses: []
  149. }),
  150. smalltalk.TrappedModelWrapper.klass);
  151. smalltalk.addClass('TrappedSingleton', smalltalk.Object, [], 'Trapped-Frontend');
  152. smalltalk.addMethod(
  153. "_start",
  154. smalltalk.method({
  155. selector: "start",
  156. category: 'action',
  157. fn: function (){
  158. var self=this;
  159. var $1;
  160. $1=smalltalk.send(self,"_subclassResponsibility",[]);
  161. return $1;
  162. },
  163. args: [],
  164. source: "start\x0a\x09^ self subclassResponsibility",
  165. messageSends: ["subclassResponsibility"],
  166. referencedClasses: []
  167. }),
  168. smalltalk.TrappedSingleton);
  169. smalltalk.TrappedSingleton.klass.iVarNames = ['current'];
  170. smalltalk.addMethod(
  171. "_current",
  172. smalltalk.method({
  173. selector: "current",
  174. category: 'accessing',
  175. fn: function (){
  176. var self=this;
  177. var $1;
  178. if(($receiver = self["@current"]) == nil || $receiver == undefined){
  179. self["@current"]=smalltalk.send(self,"_new",[]);
  180. $1=self["@current"];
  181. } else {
  182. $1=self["@current"];
  183. };
  184. return $1;
  185. },
  186. args: [],
  187. source: "current\x0a\x09^ current ifNil: [ current := self new ]",
  188. messageSends: ["ifNil:", "new"],
  189. referencedClasses: []
  190. }),
  191. smalltalk.TrappedSingleton.klass);
  192. smalltalk.addMethod(
  193. "_start",
  194. smalltalk.method({
  195. selector: "start",
  196. category: 'action',
  197. fn: function (){
  198. var self=this;
  199. smalltalk.send(smalltalk.send(self,"_current",[]),"_start",[]);
  200. return self},
  201. args: [],
  202. source: "start\x0a\x09self current start",
  203. messageSends: ["start", "current"],
  204. referencedClasses: []
  205. }),
  206. smalltalk.TrappedSingleton.klass);
  207. smalltalk.addClass('Trapped', smalltalk.TrappedSingleton, ['registry'], 'Trapped-Frontend');
  208. smalltalk.addMethod(
  209. "_byName_",
  210. smalltalk.method({
  211. selector: "byName:",
  212. category: 'accessing',
  213. fn: function (aString){
  214. var self=this;
  215. var $1;
  216. $1=smalltalk.send(self["@registry"],"_at_",[aString]);
  217. return $1;
  218. },
  219. args: ["aString"],
  220. source: "byName: aString\x0a\x09^ registry at: aString",
  221. messageSends: ["at:"],
  222. referencedClasses: []
  223. }),
  224. smalltalk.Trapped);
  225. smalltalk.addMethod(
  226. "_initialize",
  227. smalltalk.method({
  228. selector: "initialize",
  229. category: 'initialization',
  230. fn: function (){
  231. var self=this;
  232. smalltalk.send(self,"_initialize",[],smalltalk.TrappedSingleton);
  233. self["@registry"]=smalltalk.HashedCollection._fromPairs_([]);
  234. return self},
  235. args: [],
  236. source: "initialize\x0a\x09super initialize.\x0a\x09registry := #{}.",
  237. messageSends: ["initialize"],
  238. referencedClasses: []
  239. }),
  240. smalltalk.Trapped);
  241. smalltalk.addMethod(
  242. "_register_name_",
  243. smalltalk.method({
  244. selector: "register:name:",
  245. category: 'accessing',
  246. fn: function (aFly,aString){
  247. var self=this;
  248. smalltalk.send(self["@registry"],"_at_put_",[aString,aFly]);
  249. return self},
  250. args: ["aFly", "aString"],
  251. source: "register: aFly name: aString\x0a\x09registry at: aString put: aFly",
  252. messageSends: ["at:put:"],
  253. referencedClasses: []
  254. }),
  255. smalltalk.Trapped);
  256. smalltalk.addMethod(
  257. "_start",
  258. smalltalk.method({
  259. selector: "start",
  260. category: 'action',
  261. fn: function (){
  262. var self=this;
  263. var $1;
  264. smalltalk.send(smalltalk.send("[data-trap]","_asJQuery",[]),"_each_",[(function(index,elem){
  265. var trap;
  266. var jq;
  267. var viewName;
  268. var modelName;
  269. var tokens;
  270. var path;
  271. jq=smalltalk.send(elem,"_asJQuery",[]);
  272. jq;
  273. trap=smalltalk.send(jq,"_attr_",["data-trap"]);
  274. trap;
  275. tokens=smalltalk.send(trap,"_tokenize_",[":"]);
  276. tokens;
  277. $1=smalltalk.send(smalltalk.send(tokens,"_size",[]),"__eq",[(1)]);
  278. if(smalltalk.assert($1)){
  279. tokens=smalltalk.send(["TrappedDumbView"],"__comma",[tokens]);
  280. tokens;
  281. };
  282. viewName=smalltalk.send(tokens,"_first",[]);
  283. viewName;
  284. tokens=smalltalk.send(smalltalk.send(smalltalk.send(tokens,"_second",[]),"_tokenize_",[" "]),"_select_",[(function(each){
  285. return smalltalk.send(each,"_notEmpty",[]);
  286. })]);
  287. tokens;
  288. modelName=smalltalk.send(tokens,"_first",[]);
  289. modelName;
  290. path=smalltalk.send((smalltalk.Trapped || Trapped),"_parse_",[smalltalk.send(tokens,"_allButFirst",[])]);
  291. path;
  292. return smalltalk.send(smalltalk.send([modelName],"__comma",[path]),"_trapDescend_",[(function(){
  293. return smalltalk.send(smalltalk.send(smalltalk.send(smalltalk.send((smalltalk.Smalltalk || Smalltalk),"_current",[]),"_at_",[viewName]),"_new",[]),"_appendToJQuery_",[jq]);
  294. })]);
  295. })]);
  296. return self},
  297. args: [],
  298. source: "start\x0a\x09'[data-trap]' asJQuery each: [ :index :elem |\x0a \x09| trap jq viewName modelName tokens path |\x0a jq := elem asJQuery.\x0a trap := jq attr: 'data-trap'.\x0a tokens := trap tokenize: ':'.\x0a tokens size = 1 ifTrue: [ tokens := { 'TrappedDumbView' }, tokens ].\x0a viewName := tokens first.\x0a tokens := (tokens second tokenize: ' ') select: [ :each | each notEmpty ].\x0a modelName := tokens first.\x0a path := Trapped parse: tokens allButFirst.\x0a { modelName }, path trapDescend: [(Smalltalk current at: viewName) new appendToJQuery: jq].\x0a ]",
  299. messageSends: ["each:", "asJQuery", "attr:", "tokenize:", "ifTrue:", ",", "=", "size", "first", "select:", "notEmpty", "second", "parse:", "allButFirst", "trapDescend:", "appendToJQuery:", "new", "at:", "current"],
  300. referencedClasses: ["Trapped", "Smalltalk"]
  301. }),
  302. smalltalk.Trapped);
  303. smalltalk.addMethod(
  304. "_parse_",
  305. smalltalk.method({
  306. selector: "parse:",
  307. category: 'accessing',
  308. fn: function (anArray){
  309. var self=this;
  310. var $2,$3,$1;
  311. $1=smalltalk.send(anArray,"_collect_",[(function(each){
  312. var asNum;
  313. asNum = parseInt(each);
  314. ;
  315. $2=smalltalk.send(asNum,"__eq",[asNum]);
  316. if(smalltalk.assert($2)){
  317. return asNum;
  318. } else {
  319. $3=smalltalk.send(smalltalk.send(each,"_first",[]),"__eq",["#"]);
  320. if(smalltalk.assert($3)){
  321. return smalltalk.send(smalltalk.send(each,"_allButFirst",[]),"_asSymbol",[]);
  322. } else {
  323. return each;
  324. };
  325. };
  326. })]);
  327. return $1;
  328. },
  329. args: ["anArray"],
  330. source: "parse: anArray\x0a\x09^anArray collect: [ :each |\x0a \x09| asNum |\x0a \x09<asNum = parseInt(each)>.\x0a asNum = asNum ifTrue: [ asNum ] ifFalse: [\x0a\x09\x09\x09each first = '#' ifTrue: [ each allButFirst asSymbol ] ifFalse: [ each ]]]",
  331. messageSends: ["collect:", "ifTrue:ifFalse:", "asSymbol", "allButFirst", "=", "first"],
  332. referencedClasses: []
  333. }),
  334. smalltalk.Trapped.klass);
  335. smalltalk.addMethod(
  336. "_path",
  337. smalltalk.method({
  338. selector: "path",
  339. category: 'accessing',
  340. fn: function (){
  341. var self=this;
  342. var $1;
  343. $1=smalltalk.send(smalltalk.send((smalltalk.TrappedPathStack || TrappedPathStack),"_current",[]),"_elements",[]);
  344. return $1;
  345. },
  346. args: [],
  347. source: "path\x0a\x09^TrappedPathStack current elements",
  348. messageSends: ["elements", "current"],
  349. referencedClasses: ["TrappedPathStack"]
  350. }),
  351. smalltalk.Trapped.klass);
  352. smalltalk.addClass('TrappedPathStack', smalltalk.TrappedSingleton, ['elements'], 'Trapped-Frontend');
  353. smalltalk.addMethod(
  354. "_append_",
  355. smalltalk.method({
  356. selector: "append:",
  357. category: 'descending',
  358. fn: function (anArray){
  359. var self=this;
  360. self["@elements"]=smalltalk.send(self["@elements"],"__comma",[anArray]);
  361. return self},
  362. args: ["anArray"],
  363. source: "append: anArray\x0a elements := elements, anArray",
  364. messageSends: [","],
  365. referencedClasses: []
  366. }),
  367. smalltalk.TrappedPathStack);
  368. smalltalk.addMethod(
  369. "_elements",
  370. smalltalk.method({
  371. selector: "elements",
  372. category: 'accessing',
  373. fn: function (){
  374. var self=this;
  375. return self["@elements"];
  376. },
  377. args: [],
  378. source: "elements\x0a\x09^elements",
  379. messageSends: [],
  380. referencedClasses: []
  381. }),
  382. smalltalk.TrappedPathStack);
  383. smalltalk.addMethod(
  384. "_initialize",
  385. smalltalk.method({
  386. selector: "initialize",
  387. category: 'initialization',
  388. fn: function (){
  389. var self=this;
  390. smalltalk.send(self,"_initialize",[],smalltalk.TrappedSingleton);
  391. self["@elements"]=[];
  392. return self},
  393. args: [],
  394. source: "initialize\x0a super initialize.\x0a\x09elements := #().",
  395. messageSends: ["initialize"],
  396. referencedClasses: []
  397. }),
  398. smalltalk.TrappedPathStack);
  399. smalltalk.addMethod(
  400. "_with_do_",
  401. smalltalk.method({
  402. selector: "with:do:",
  403. category: 'descending',
  404. fn: function (anArray,aBlock){
  405. var self=this;
  406. var old;
  407. old=self["@elements"];
  408. smalltalk.send((function(){
  409. smalltalk.send(self,"_append_",[anArray]);
  410. return smalltalk.send(aBlock,"_value",[]);
  411. }),"_ensure_",[(function(){
  412. self["@elements"]=old;
  413. return self["@elements"];
  414. })]);
  415. return self},
  416. args: ["anArray", "aBlock"],
  417. source: "with: anArray do: aBlock\x0a\x09| old |\x0a old := elements.\x0a [ self append: anArray.\x0a\x09aBlock value ] ensure: [ elements := old ]",
  418. messageSends: ["ensure:", "append:", "value"],
  419. referencedClasses: []
  420. }),
  421. smalltalk.TrappedPathStack);
  422. smalltalk.addMethod(
  423. "_trapDescend_",
  424. smalltalk.method({
  425. selector: "trapDescend:",
  426. category: '*Trapped-Frontend',
  427. fn: function (aBlock){
  428. var self=this;
  429. smalltalk.send(smalltalk.send((smalltalk.TrappedPathStack || TrappedPathStack),"_current",[]),"_with_do_",[self,aBlock]);
  430. return self},
  431. args: ["aBlock"],
  432. source: "trapDescend: aBlock\x0a\x09TrappedPathStack current with: self do: aBlock",
  433. messageSends: ["with:do:", "current"],
  434. referencedClasses: ["TrappedPathStack"]
  435. }),
  436. smalltalk.Array);
  437. smalltalk.addMethod(
  438. "_trapDescend_",
  439. smalltalk.method({
  440. selector: "trapDescend:",
  441. category: '*Trapped-Frontend',
  442. fn: function (aBlock){
  443. var self=this;
  444. smalltalk.send(smalltalk.send((smalltalk.TrappedPathStack || TrappedPathStack),"_current",[]),"_with_do_",[self,aBlock]);
  445. return self},
  446. args: ["aBlock"],
  447. source: "trapDescend: aBlock\x0a\x09TrappedPathStack current with: self do: aBlock",
  448. messageSends: ["with:do:", "current"],
  449. referencedClasses: ["TrappedPathStack"]
  450. }),
  451. smalltalk.Array);
  452. smalltalk.addMethod(
  453. "_trap_read_",
  454. smalltalk.method({
  455. selector: "trap:read:",
  456. category: '*Trapped-Frontend',
  457. fn: function (path,aBlock){
  458. var self=this;
  459. var $1;
  460. smalltalk.send(path,"_trapDescend_",[(function(){
  461. var actual;
  462. var model;
  463. actual=smalltalk.send((smalltalk.Trapped || Trapped),"_path",[]);
  464. actual;
  465. model=smalltalk.send(smalltalk.send((smalltalk.Trapped || Trapped),"_current",[]),"_byName_",[smalltalk.send(actual,"_first",[])]);
  466. model;
  467. return smalltalk.send(model,"_watch_do_",[smalltalk.send(actual,"_allButFirst",[]),(function(data){
  468. $1=smalltalk.send(smalltalk.send(smalltalk.send(smalltalk.send(self,"_asJQuery",[]),"_closest_",["html"]),"_toArray",[]),"_isEmpty",[]);
  469. if(smalltalk.assert($1)){
  470. smalltalk.send((smalltalk.TrappedUnwatch || TrappedUnwatch),"_signal",[]);
  471. };
  472. return smalltalk.send(actual,"_trapDescend_",[(function(){
  473. return smalltalk.send(self,"_with_",[(function(html){
  474. return smalltalk.send(aBlock,"_value_value_",[data,html]);
  475. })]);
  476. })]);
  477. })]);
  478. })]);
  479. return self},
  480. args: ["path", "aBlock"],
  481. source: "trap: path read: aBlock\x0a\x09path trapDescend: [ | actual model |\x0a \x09actual := Trapped path.\x0a model := Trapped current byName: actual first.\x0a model watch: actual allButFirst do: [ :data |\x0a (self asJQuery closest: 'html') toArray isEmpty ifTrue: [ TrappedUnwatch signal ].\x0a \x09actual trapDescend: [ self with: [ :html | aBlock value: data value: html ] ]\x0a \x09]\x0a ]",
  482. messageSends: ["trapDescend:", "path", "byName:", "first", "current", "watch:do:", "allButFirst", "ifTrue:", "signal", "isEmpty", "toArray", "closest:", "asJQuery", "with:", "value:value:"],
  483. referencedClasses: ["Trapped", "TrappedUnwatch"]
  484. }),
  485. smalltalk.TagBrush);
  486. smalltalk.addMethod(
  487. "_trap_toggle_",
  488. smalltalk.method({
  489. selector: "trap:toggle:",
  490. category: '*Trapped-Frontend',
  491. fn: function (path,aBlock){
  492. var self=this;
  493. smalltalk.send(self,"_trap_toggle_ifNotPresent_",[path,aBlock,(function(){
  494. return smalltalk.send(smalltalk.send(self,"_asJQuery",[]),"_hide",[]);
  495. })]);
  496. return self},
  497. args: ["path", "aBlock"],
  498. source: "trap: path toggle: aBlock\x0a self trap: path toggle: aBlock ifNotPresent: [ self asJQuery hide ]",
  499. messageSends: ["trap:toggle:ifNotPresent:", "hide", "asJQuery"],
  500. referencedClasses: []
  501. }),
  502. smalltalk.TagBrush);
  503. smalltalk.addMethod(
  504. "_trap_toggle_ifNotPresent_",
  505. smalltalk.method({
  506. selector: "trap:toggle:ifNotPresent:",
  507. category: '*Trapped-Frontend',
  508. fn: function (path,aBlock,anotherBlock){
  509. var self=this;
  510. var $1,$2,$3,$4;
  511. var shown;
  512. shown=nil;
  513. smalltalk.send(self,"_trap_read_",[path,(function(data,html){
  514. $1=smalltalk.send(shown,"__eq",[smalltalk.send(data,"_notNil",[])]);
  515. if(! smalltalk.assert($1)){
  516. shown=smalltalk.send(data,"_notNil",[]);
  517. shown;
  518. $2=smalltalk.send(self,"_asJQuery",[]);
  519. smalltalk.send($2,"_empty",[]);
  520. $3=smalltalk.send($2,"_show",[]);
  521. $3;
  522. if(smalltalk.assert(shown)){
  523. $4=aBlock;
  524. } else {
  525. $4=anotherBlock;
  526. };
  527. return smalltalk.send($4,"_value_value_",[data,html]);
  528. };
  529. })]);
  530. return self},
  531. args: ["path", "aBlock", "anotherBlock"],
  532. source: "trap: path toggle: aBlock ifNotPresent: anotherBlock\x0a | shown |\x0a shown := nil.\x0a self trap: path read: [ :data : html |\x0a shown = data notNil ifFalse: [\x0a shown := data notNil.\x0a self asJQuery empty; show.\x0a (shown ifTrue: [aBlock] ifFalse: [anotherBlock]) value: data value: html.\x0a ]\x0a ]",
  533. messageSends: ["trap:read:", "ifFalse:", "notNil", "empty", "asJQuery", "show", "value:value:", "ifTrue:ifFalse:", "="],
  534. referencedClasses: []
  535. }),
  536. smalltalk.TagBrush);
  537. smalltalk.addMethod(
  538. "_trapIter_tag_do_",
  539. smalltalk.method({
  540. selector: "trapIter:tag:do:",
  541. category: '*Trapped-Frontend',
  542. fn: function (path,aSymbol,aBlock){
  543. var self=this;
  544. smalltalk.send(self,"_trap_read_",[path,(function(model,html){
  545. smalltalk.send(smalltalk.send(html,"_root",[]),"_empty",[]);
  546. if(($receiver = model) == nil || $receiver == undefined){
  547. return model;
  548. } else {
  549. return smalltalk.send(model,"_withIndexDo_",[(function(item,i){
  550. return smalltalk.send(smalltalk.send(html,"_perform_",[aSymbol]),"_trap_read_",[[i],aBlock]);
  551. })]);
  552. };
  553. })]);
  554. return self},
  555. args: ["path", "aSymbol", "aBlock"],
  556. source: "trapIter: path tag: aSymbol do: aBlock\x0a self trap: path read: [ :model :html |\x0a html root empty.\x0a model ifNotNil: [ model withIndexDo: [ :item :i |\x0a (html perform: aSymbol) trap: {i} read: aBlock\x0a ]]\x0a ]",
  557. messageSends: ["trap:read:", "empty", "root", "ifNotNil:", "withIndexDo:", "perform:"],
  558. referencedClasses: []
  559. }),
  560. smalltalk.TagBrush);
  561. smalltalk.addMethod(
  562. "_trapShow_",
  563. smalltalk.method({
  564. selector: "trapShow:",
  565. category: '*Trapped-Frontend',
  566. fn: function (path){
  567. var self=this;
  568. smalltalk.send(self,"_trapShow_default_",[path,(function(){
  569. })]);
  570. return self},
  571. args: ["path"],
  572. source: "trapShow: path\x0a\x09self trapShow: path default: []",
  573. messageSends: ["trapShow:default:"],
  574. referencedClasses: []
  575. }),
  576. smalltalk.TagBrush);
  577. smalltalk.addMethod(
  578. "_trapShow_default_",
  579. smalltalk.method({
  580. selector: "trapShow:default:",
  581. category: '*Trapped-Frontend',
  582. fn: function (path,anObject){
  583. var self=this;
  584. var $2,$1;
  585. smalltalk.send(self,"_trap_read_",[path,(function(model){
  586. smalltalk.send(self,"_empty",[]);
  587. if(($receiver = model) == nil || $receiver == undefined){
  588. $2=anObject;
  589. } else {
  590. $2=model;
  591. };
  592. $1=smalltalk.send(self,"_with_",[$2]);
  593. return $1;
  594. })]);
  595. return self},
  596. args: ["path", "anObject"],
  597. source: "trapShow: path default: anObject\x0a\x09self trap: path read: [ :model | self empty; with: (model ifNil: [anObject]) ]",
  598. messageSends: ["trap:read:", "empty", "with:", "ifNil:"],
  599. referencedClasses: []
  600. }),
  601. smalltalk.TagBrush);