canvas.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934
  1. smalltalk.addClass('HTMLCanvas', smalltalk.Object, ['root'], 'Canvas');
  2. smalltalk.addMethod(
  3. '_root_',
  4. smalltalk.method({
  5. selector: 'root:',
  6. category: 'accessing',
  7. fn: function (aTagBrush){
  8. var self=this;
  9. self['@root']=aTagBrush;
  10. return self;},
  11. source: unescape('root%3A%20aTagBrush%0A%20%20%20%20root%20%3A%3D%20aTagBrush%0A')}),
  12. smalltalk.HTMLCanvas);
  13. smalltalk.addMethod(
  14. '_root',
  15. smalltalk.method({
  16. selector: 'root',
  17. category: 'accessing',
  18. fn: function (){
  19. var self=this;
  20. return self['@root'];
  21. return self;},
  22. source: unescape('root%0A%20%20%20%20%5Eroot%0A')}),
  23. smalltalk.HTMLCanvas);
  24. smalltalk.addMethod(
  25. '_initialize',
  26. smalltalk.method({
  27. selector: 'initialize',
  28. category: 'initialization',
  29. fn: function (){
  30. var self=this;
  31. self.klass.superclass.fn.prototype['_initialize'].apply(self, []);
  32. self['@root']=smalltalk.TagBrush._fromString_canvas_("div",self);
  33. return self;},
  34. source: unescape('initialize%0A%20%20%20%20super%20initialize.%0A%20%20%20%20root%20%3A%3D%20TagBrush%20fromString%3A%20%27div%27%20canvas%3A%20self%0A')}),
  35. smalltalk.HTMLCanvas);
  36. smalltalk.addMethod(
  37. '_with_',
  38. smalltalk.method({
  39. selector: 'with:',
  40. category: 'adding',
  41. fn: function (anObject){
  42. var self=this;
  43. return self._root()._with_(anObject);
  44. return self;},
  45. source: unescape('with%3A%20anObject%0A%20%20%20%20%5Eself%20root%20with%3A%20anObject%0A')}),
  46. smalltalk.HTMLCanvas);
  47. smalltalk.addMethod(
  48. '_newTag_',
  49. smalltalk.method({
  50. selector: 'newTag:',
  51. category: 'tags',
  52. fn: function (aString){
  53. var self=this;
  54. return smalltalk.TagBrush._fromString_canvas_(aString,self);
  55. return self;},
  56. source: unescape('newTag%3A%20aString%0A%20%20%20%20%5ETagBrush%20fromString%3A%20aString%20canvas%3A%20self%0A')}),
  57. smalltalk.HTMLCanvas);
  58. smalltalk.addMethod(
  59. '_tag_',
  60. smalltalk.method({
  61. selector: 'tag:',
  62. category: 'tags',
  63. fn: function (aString){
  64. var self=this;
  65. return self['@root']._addBrush_(self._newTag_(aString));
  66. return self;},
  67. source: unescape('tag%3A%20aString%0A%20%20%20%20%5Eroot%20addBrush%3A%20%28self%20newTag%3A%20aString%29%0A')}),
  68. smalltalk.HTMLCanvas);
  69. smalltalk.addMethod(
  70. '_h1',
  71. smalltalk.method({
  72. selector: 'h1',
  73. category: 'tags',
  74. fn: function (){
  75. var self=this;
  76. return self._tag_("h1");
  77. return self;},
  78. source: unescape('h1%0A%20%20%20%20%5Eself%20tag%3A%20%27h1%27%0A')}),
  79. smalltalk.HTMLCanvas);
  80. smalltalk.addMethod(
  81. '_h2',
  82. smalltalk.method({
  83. selector: 'h2',
  84. category: 'tags',
  85. fn: function (){
  86. var self=this;
  87. return self._tag_("h2");
  88. return self;},
  89. source: unescape('h2%0A%20%20%20%20%5Eself%20tag%3A%20%27h2%27%0A')}),
  90. smalltalk.HTMLCanvas);
  91. smalltalk.addMethod(
  92. '_h3',
  93. smalltalk.method({
  94. selector: 'h3',
  95. category: 'tags',
  96. fn: function (){
  97. var self=this;
  98. return self._tag_("h3");
  99. return self;},
  100. source: unescape('h3%0A%20%20%20%20%5Eself%20tag%3A%20%27h3%27%0A')}),
  101. smalltalk.HTMLCanvas);
  102. smalltalk.addMethod(
  103. '_h4',
  104. smalltalk.method({
  105. selector: 'h4',
  106. category: 'tags',
  107. fn: function (){
  108. var self=this;
  109. return self._tag_("h4");
  110. return self;},
  111. source: unescape('h4%0A%20%20%20%20%5Eself%20tag%3A%20%27h4%27%0A')}),
  112. smalltalk.HTMLCanvas);
  113. smalltalk.addMethod(
  114. '_h5',
  115. smalltalk.method({
  116. selector: 'h5',
  117. category: 'tags',
  118. fn: function (){
  119. var self=this;
  120. return self._tag_("h5");
  121. return self;},
  122. source: unescape('h5%0A%20%20%20%20%5Eself%20tag%3A%20%27h5%27%0A')}),
  123. smalltalk.HTMLCanvas);
  124. smalltalk.addMethod(
  125. '_h6',
  126. smalltalk.method({
  127. selector: 'h6',
  128. category: 'tags',
  129. fn: function (){
  130. var self=this;
  131. return self._tag_("h6");
  132. return self;},
  133. source: unescape('h6%0A%20%20%20%20%5Eself%20tag%3A%20%27h6%27%0A')}),
  134. smalltalk.HTMLCanvas);
  135. smalltalk.addMethod(
  136. '_p',
  137. smalltalk.method({
  138. selector: 'p',
  139. category: 'tags',
  140. fn: function (){
  141. var self=this;
  142. return self._tag_("p");
  143. return self;},
  144. source: unescape('p%0A%20%20%20%20%5Eself%20tag%3A%20%27p%27%0A')}),
  145. smalltalk.HTMLCanvas);
  146. smalltalk.addMethod(
  147. '_div',
  148. smalltalk.method({
  149. selector: 'div',
  150. category: 'tags',
  151. fn: function (){
  152. var self=this;
  153. return self._tag_("div");
  154. return self;},
  155. source: unescape('div%0A%20%20%20%20%5Eself%20tag%3A%20%27div%27%0A')}),
  156. smalltalk.HTMLCanvas);
  157. smalltalk.addMethod(
  158. '_span',
  159. smalltalk.method({
  160. selector: 'span',
  161. category: 'tags',
  162. fn: function (){
  163. var self=this;
  164. return self._tag_("span");
  165. return self;},
  166. source: unescape('span%0A%20%20%20%20%5Eself%20tag%3A%20%27span%27%0A')}),
  167. smalltalk.HTMLCanvas);
  168. smalltalk.addMethod(
  169. '_img',
  170. smalltalk.method({
  171. selector: 'img',
  172. category: 'tags',
  173. fn: function (){
  174. var self=this;
  175. return self._tag_("img");
  176. return self;},
  177. source: unescape('img%0A%20%20%20%20%5Eself%20tag%3A%20%27img%27%0A')}),
  178. smalltalk.HTMLCanvas);
  179. smalltalk.addMethod(
  180. '_ul',
  181. smalltalk.method({
  182. selector: 'ul',
  183. category: 'tags',
  184. fn: function (){
  185. var self=this;
  186. return self._tag_("ul");
  187. return self;},
  188. source: unescape('ul%0A%20%20%20%20%5Eself%20tag%3A%20%27ul%27%0A')}),
  189. smalltalk.HTMLCanvas);
  190. smalltalk.addMethod(
  191. '_ol',
  192. smalltalk.method({
  193. selector: 'ol',
  194. category: 'tags',
  195. fn: function (){
  196. var self=this;
  197. return self._tag_("ol");
  198. return self;},
  199. source: unescape('ol%0A%20%20%20%20%5Eself%20tag%3A%20%27ol%27%0A')}),
  200. smalltalk.HTMLCanvas);
  201. smalltalk.addMethod(
  202. '_li',
  203. smalltalk.method({
  204. selector: 'li',
  205. category: 'tags',
  206. fn: function (){
  207. var self=this;
  208. return self._tag_("li");
  209. return self;},
  210. source: unescape('li%0A%20%20%20%20%5Eself%20tag%3A%20%27li%27%0A')}),
  211. smalltalk.HTMLCanvas);
  212. smalltalk.addMethod(
  213. '_table',
  214. smalltalk.method({
  215. selector: 'table',
  216. category: 'tags',
  217. fn: function (){
  218. var self=this;
  219. return self._tag_("table");
  220. return self;},
  221. source: unescape('table%0A%20%20%20%20%5Eself%20tag%3A%20%27table%27%0A')}),
  222. smalltalk.HTMLCanvas);
  223. smalltalk.addMethod(
  224. '_tr',
  225. smalltalk.method({
  226. selector: 'tr',
  227. category: 'tags',
  228. fn: function (){
  229. var self=this;
  230. return self._tag_("tr");
  231. return self;},
  232. source: unescape('tr%0A%20%20%20%20%5Eself%20tag%3A%20%27tr%27%0A')}),
  233. smalltalk.HTMLCanvas);
  234. smalltalk.addMethod(
  235. '_td',
  236. smalltalk.method({
  237. selector: 'td',
  238. category: 'tags',
  239. fn: function (){
  240. var self=this;
  241. return self._tag_("td");
  242. return self;},
  243. source: unescape('td%20%0A%20%20%20%20%5Eself%20tag%3A%20%27td%27%0A')}),
  244. smalltalk.HTMLCanvas);
  245. smalltalk.addMethod(
  246. '_th',
  247. smalltalk.method({
  248. selector: 'th',
  249. category: 'tags',
  250. fn: function (){
  251. var self=this;
  252. return self._tag_("th");
  253. return self;},
  254. source: unescape('th%0A%20%20%20%20%5Eself%20tag%3A%20%27th%27%0A')}),
  255. smalltalk.HTMLCanvas);
  256. smalltalk.addMethod(
  257. '_form',
  258. smalltalk.method({
  259. selector: 'form',
  260. category: 'tags',
  261. fn: function (){
  262. var self=this;
  263. return self._tag_("form");
  264. return self;},
  265. source: unescape('form%0A%20%20%20%20%5Eself%20tag%3A%20%27form%27%0A')}),
  266. smalltalk.HTMLCanvas);
  267. smalltalk.addMethod(
  268. '_input',
  269. smalltalk.method({
  270. selector: 'input',
  271. category: 'tags',
  272. fn: function (){
  273. var self=this;
  274. return self._tag_("input");
  275. return self;},
  276. source: unescape('input%0A%20%20%20%20%5Eself%20tag%3A%20%27input%27%0A')}),
  277. smalltalk.HTMLCanvas);
  278. smalltalk.addMethod(
  279. '_button',
  280. smalltalk.method({
  281. selector: 'button',
  282. category: 'tags',
  283. fn: function (){
  284. var self=this;
  285. return self._tag_("button");
  286. return self;},
  287. source: unescape('button%0A%20%20%20%20%5Eself%20tag%3A%20%27button%27%0A')}),
  288. smalltalk.HTMLCanvas);
  289. smalltalk.addMethod(
  290. '_select',
  291. smalltalk.method({
  292. selector: 'select',
  293. category: 'tags',
  294. fn: function (){
  295. var self=this;
  296. return self._tag_("select");
  297. return self;},
  298. source: unescape('select%0A%20%20%20%20%5Eself%20tag%3A%20%27select%27%0A')}),
  299. smalltalk.HTMLCanvas);
  300. smalltalk.addMethod(
  301. '_option',
  302. smalltalk.method({
  303. selector: 'option',
  304. category: 'tags',
  305. fn: function (){
  306. var self=this;
  307. return self._tag_("option");
  308. return self;},
  309. source: unescape('option%0A%20%20%20%20%5Eself%20tag%3A%20%27option%27%0A')}),
  310. smalltalk.HTMLCanvas);
  311. smalltalk.addMethod(
  312. '_textarea',
  313. smalltalk.method({
  314. selector: 'textarea',
  315. category: 'tags',
  316. fn: function (){
  317. var self=this;
  318. return self._tag_("textarea");
  319. return self;},
  320. source: unescape('textarea%0A%20%20%20%20%5Eself%20tag%3A%20%27textarea%27%0A')}),
  321. smalltalk.HTMLCanvas);
  322. smalltalk.addMethod(
  323. '_a',
  324. smalltalk.method({
  325. selector: 'a',
  326. category: 'tags',
  327. fn: function (){
  328. var self=this;
  329. return self._tag_("a");
  330. return self;},
  331. source: unescape('a%0A%20%20%20%20%5Eself%20tag%3A%20%27a%27%0A')}),
  332. smalltalk.HTMLCanvas);
  333. smalltalk.addMethod(
  334. '_appendToJQuery_',
  335. smalltalk.method({
  336. selector: 'appendToJQuery:',
  337. category: '*JQuery',
  338. fn: function (aJQuery){
  339. var self=this;
  340. aJQuery._appendElement_(self['@root']._element());
  341. return self;},
  342. source: unescape('appendToJQuery%3A%20aJQuery%0A%20%20%20%20aJQuery%20appendElement%3A%20root%20element%0A')}),
  343. smalltalk.HTMLCanvas);
  344. smalltalk.addClass('TagBrush', smalltalk.Object, ['element'], 'Canvas');
  345. smalltalk.addMethod(
  346. '_contents_',
  347. smalltalk.method({
  348. selector: 'contents:',
  349. category: 'adding',
  350. fn: function (anObject){
  351. var self=this;
  352. self._asJQuery()._empty();
  353. self._append_(anObject);
  354. return self;},
  355. source: unescape('contents%3A%20anObject%0A%20%20%20%20self%20asJQuery%20empty.%0A%20%20%20%20self%20append%3A%20anObject%0A')}),
  356. smalltalk.TagBrush);
  357. smalltalk.addMethod(
  358. '_addBrush_',
  359. smalltalk.method({
  360. selector: 'addBrush:',
  361. category: 'adding',
  362. fn: function (aTagBrush){
  363. var self=this;
  364. self._appendChild_(aTagBrush._element());
  365. return aTagBrush;
  366. return self;},
  367. source: unescape('addBrush%3A%20aTagBrush%0A%20%20%20%20self%20appendChild%3A%20aTagBrush%20element.%0A%20%20%20%20%5EaTagBrush%0A')}),
  368. smalltalk.TagBrush);
  369. smalltalk.addMethod(
  370. '_with_',
  371. smalltalk.method({
  372. selector: 'with:',
  373. category: 'adding',
  374. fn: function (anObject){
  375. var self=this;
  376. self._append_(anObject);
  377. return self;},
  378. source: unescape('with%3A%20anObject%0A%20%20%20%20self%20append%3A%20anObject%0A')}),
  379. smalltalk.TagBrush);
  380. smalltalk.addMethod(
  381. '_append_',
  382. smalltalk.method({
  383. selector: 'append:',
  384. category: 'adding',
  385. fn: function (anObject){
  386. var self=this;
  387. anObject._appendToBrush_(self);
  388. return self;},
  389. source: unescape('append%3A%20anObject%0A%20%20%20%20anObject%20appendToBrush%3A%20self%0A')}),
  390. smalltalk.TagBrush);
  391. smalltalk.addMethod(
  392. '_appendToBrush_',
  393. smalltalk.method({
  394. selector: 'appendToBrush:',
  395. category: 'adding',
  396. fn: function (aTagBrush){
  397. var self=this;
  398. aTagBrush._addBrush_(self);
  399. return self;},
  400. source: unescape('appendToBrush%3A%20aTagBrush%0A%20%20%20%20aTagBrush%20addBrush%3A%20self%0A')}),
  401. smalltalk.TagBrush);
  402. smalltalk.addMethod(
  403. '_appendBlock_',
  404. smalltalk.method({
  405. selector: 'appendBlock:',
  406. category: 'adding',
  407. fn: function (aBlock){
  408. var self=this;
  409. var root=nil;
  410. root=canvas._root();
  411. canvas._root_(self);
  412. aBlock._value_(canvas);
  413. canvas._root_(root);
  414. return self;},
  415. source: unescape('appendBlock%3A%20aBlock%0A%20%20%20%20%7C%20root%20%7C%0A%20%20%20%20root%20%3A%3D%20canvas%20root.%0A%20%20%20%20canvas%20root%3A%20self.%0A%20%20%20%20aBlock%20value%3A%20canvas.%0A%20%20%20%20canvas%20root%3A%20root%0A')}),
  416. smalltalk.TagBrush);
  417. smalltalk.addMethod(
  418. '_appendChild_',
  419. smalltalk.method({
  420. selector: 'appendChild:',
  421. category: 'adding',
  422. fn: function (anElement){
  423. var self=this;
  424. (function(){self['@element'].appendChild(anElement)})();
  425. return self;},
  426. source: unescape('appendChild%3A%20anElement%0A%20%20%20%20%7B%27self%5B%27%27@element%27%27%5D.appendChild%28anElement%29%27%7D%0A')}),
  427. smalltalk.TagBrush);
  428. smalltalk.addMethod(
  429. '_appendString_',
  430. smalltalk.method({
  431. selector: 'appendString:',
  432. category: 'adding',
  433. fn: function (aString){
  434. var self=this;
  435. self._appendChild_(self._createTextNodeFor_(aString));
  436. return self;},
  437. source: unescape('appendString%3A%20aString%0A%20%20%20%20self%20appendChild%3A%20%28self%20createTextNodeFor%3A%20aString%29%0A')}),
  438. smalltalk.TagBrush);
  439. smalltalk.addMethod(
  440. '_at_put_',
  441. smalltalk.method({
  442. selector: 'at:put:',
  443. category: 'attributes',
  444. fn: function (aString, aValue){
  445. var self=this;
  446. (function(){self['@element'].setAttribute(aString, aValue)})();
  447. return self;},
  448. source: unescape('at%3A%20aString%20put%3A%20aValue%0A%20%20%20%20%7B%27self%5B%27%27@element%27%27%5D.setAttribute%28aString%2C%20aValue%29%27%7D%0A')}),
  449. smalltalk.TagBrush);
  450. smalltalk.addMethod(
  451. '_removeAt_',
  452. smalltalk.method({
  453. selector: 'removeAt:',
  454. category: 'attributes',
  455. fn: function (aString){
  456. var self=this;
  457. (function(){self['@element'].removeAttribute(aString)})();
  458. return self;},
  459. source: unescape('removeAt%3A%20aString%0A%20%20%20%20%7B%27self%5B%27%27@element%27%27%5D.removeAttribute%28aString%29%27%7D%0A')}),
  460. smalltalk.TagBrush);
  461. smalltalk.addMethod(
  462. '_class_',
  463. smalltalk.method({
  464. selector: 'class:',
  465. category: 'attributes',
  466. fn: function (aString){
  467. var self=this;
  468. self._at_put_("class",aString);
  469. return self;},
  470. source: unescape('class%3A%20aString%0A%20%20%20%20self%20at%3A%20%27class%27%20put%3A%20aString%0A')}),
  471. smalltalk.TagBrush);
  472. smalltalk.addMethod(
  473. '_id_',
  474. smalltalk.method({
  475. selector: 'id:',
  476. category: 'attributes',
  477. fn: function (aString){
  478. var self=this;
  479. self._at_put_("id",aString);
  480. return self;},
  481. source: unescape('id%3A%20aString%0A%20%20%20%20self%20at%3A%20%27id%27%20put%3A%20aString%0A')}),
  482. smalltalk.TagBrush);
  483. smalltalk.addMethod(
  484. '_src_',
  485. smalltalk.method({
  486. selector: 'src:',
  487. category: 'attributes',
  488. fn: function (aString){
  489. var self=this;
  490. self._at_put_("src",aString);
  491. return self;},
  492. source: unescape('src%3A%20aString%0A%20%20%20%20self%20%20at%3A%20%27src%27%20put%3A%20aString%0A')}),
  493. smalltalk.TagBrush);
  494. smalltalk.addMethod(
  495. '_href_',
  496. smalltalk.method({
  497. selector: 'href:',
  498. category: 'attributes',
  499. fn: function (aString){
  500. var self=this;
  501. self._at_put_("href",aString);
  502. return self;},
  503. source: unescape('href%3A%20aString%0A%20%20%20%20self%20at%3A%20%27href%27%20put%3A%20aString%0A')}),
  504. smalltalk.TagBrush);
  505. smalltalk.addMethod(
  506. '_title_',
  507. smalltalk.method({
  508. selector: 'title:',
  509. category: 'attributes',
  510. fn: function (aString){
  511. var self=this;
  512. self._at_put_("title",aString);
  513. return self;},
  514. source: unescape('title%3A%20aString%0A%20%20%20%20self%20at%3A%20%27title%27%20put%3A%20aString%0A')}),
  515. smalltalk.TagBrush);
  516. smalltalk.addMethod(
  517. '_style_',
  518. smalltalk.method({
  519. selector: 'style:',
  520. category: 'attributes',
  521. fn: function (aString){
  522. var self=this;
  523. self._at_put_("style",aString);
  524. return self;},
  525. source: unescape('style%3A%20aString%0A%20%20%20%20self%20at%3A%20%27style%27%20put%3A%20aString%0A')}),
  526. smalltalk.TagBrush);
  527. smalltalk.addMethod(
  528. '_initializeFromString_canvas_',
  529. smalltalk.method({
  530. selector: 'initializeFromString:canvas:',
  531. category: 'initialization',
  532. fn: function (aString, aCanvas){
  533. var self=this;
  534. self['@element']=self._createElementFor_(aString);
  535. canvas=aCanvas;
  536. return self;},
  537. source: unescape('initializeFromString%3A%20aString%20canvas%3A%20aCanvas%0A%20%20%20%20element%20%3A%3D%20self%20createElementFor%3A%20aString.%0A%20%20%20%20canvas%20%3A%3D%20aCanvas%0A')}),
  538. smalltalk.TagBrush);
  539. smalltalk.addMethod(
  540. '_element',
  541. smalltalk.method({
  542. selector: 'element',
  543. category: 'accessing',
  544. fn: function (){
  545. var self=this;
  546. return self['@element'];
  547. return self;},
  548. source: unescape('element%0A%20%20%20%20%5Eelement%0A')}),
  549. smalltalk.TagBrush);
  550. smalltalk.addMethod(
  551. '_asJQuery',
  552. smalltalk.method({
  553. selector: 'asJQuery',
  554. category: 'converting',
  555. fn: function (){
  556. var self=this;
  557. return (function(){return smalltalk.JQuery._from_(jQuery(self['@element']))})();
  558. return self;},
  559. source: unescape('asJQuery%0A%20%20%20%20%5E%7B%27return%20smalltalk.JQuery._from_%28jQuery%28self%5B%27%27@element%27%27%5D%29%29%27%7D%0A')}),
  560. smalltalk.TagBrush);
  561. smalltalk.addMethod(
  562. '_asJQueryDo_',
  563. smalltalk.method({
  564. selector: 'asJQueryDo:',
  565. category: 'converting',
  566. fn: function (aBlock){
  567. var self=this;
  568. aBlock._value_(self._asJQuery());
  569. return self;},
  570. source: unescape('asJQueryDo%3A%20aBlock%0A%20%20%20%20aBlock%20value%3A%20self%20asJQuery%0A')}),
  571. smalltalk.TagBrush);
  572. smalltalk.addMethod(
  573. '_onKeyDown_',
  574. smalltalk.method({
  575. selector: 'onKeyDown:',
  576. category: 'events',
  577. fn: function (aBlock){
  578. var self=this;
  579. self._asJQuery()._on_do_("keydown",aBlock);
  580. return self;},
  581. source: unescape('onKeyDown%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27keydown%27%20do%3A%20aBlock%0A')}),
  582. smalltalk.TagBrush);
  583. smalltalk.addMethod(
  584. '_onKeyPress_',
  585. smalltalk.method({
  586. selector: 'onKeyPress:',
  587. category: 'events',
  588. fn: function (aBlock){
  589. var self=this;
  590. self._asJQuery()._on_do_("keypress",aBlock);
  591. return self;},
  592. source: unescape('onKeyPress%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27keypress%27%20do%3A%20aBlock%0A')}),
  593. smalltalk.TagBrush);
  594. smalltalk.addMethod(
  595. '_onKeyUp_',
  596. smalltalk.method({
  597. selector: 'onKeyUp:',
  598. category: 'events',
  599. fn: function (aBlock){
  600. var self=this;
  601. self._asJQuery()._on_do_("keyup",aBlock);
  602. return self;},
  603. source: unescape('onKeyUp%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27keyup%27%20do%3A%20aBlock%0A')}),
  604. smalltalk.TagBrush);
  605. smalltalk.addMethod(
  606. '_onFocus_',
  607. smalltalk.method({
  608. selector: 'onFocus:',
  609. category: 'events',
  610. fn: function (aBlock){
  611. var self=this;
  612. self._asJQuery()._on_do_("focus",aBlock);
  613. return self;},
  614. source: unescape('onFocus%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27focus%27%20do%3A%20aBlock%0A')}),
  615. smalltalk.TagBrush);
  616. smalltalk.addMethod(
  617. '_onBlur_',
  618. smalltalk.method({
  619. selector: 'onBlur:',
  620. category: 'events',
  621. fn: function (aBlock){
  622. var self=this;
  623. self._asJQuery()._on_do_("blur",aBlock);
  624. return self;},
  625. source: unescape('onBlur%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27blur%27%20do%3A%20aBlock%0A')}),
  626. smalltalk.TagBrush);
  627. smalltalk.addMethod(
  628. '_onChange_',
  629. smalltalk.method({
  630. selector: 'onChange:',
  631. category: 'events',
  632. fn: function (aBlock){
  633. var self=this;
  634. self._asJQuery()._on_do_("change",aBlock);
  635. return self;},
  636. source: unescape('onChange%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27change%27%20do%3A%20aBlock%0A')}),
  637. smalltalk.TagBrush);
  638. smalltalk.addMethod(
  639. '_onClick_',
  640. smalltalk.method({
  641. selector: 'onClick:',
  642. category: 'events',
  643. fn: function (aBlock){
  644. var self=this;
  645. self._asJQuery()._on_do_("click",aBlock);
  646. return self;},
  647. source: unescape('onClick%3A%20aBlock%0A%20%20%20%20self%20asJQuery%20on%3A%20%27click%27%20do%3A%20aBlock%0A')}),
  648. smalltalk.TagBrush);
  649. smalltalk.addMethod(
  650. '_createElementFor_',
  651. smalltalk.method({
  652. selector: 'createElementFor:',
  653. category: 'private',
  654. fn: function (aString){
  655. var self=this;
  656. return (function(){return document.createElement(String(aString))})();
  657. return self;},
  658. source: unescape('createElementFor%3A%20aString%0A%20%20%20%20%5E%7B%27return%20document.createElement%28String%28aString%29%29%27%7D%0A')}),
  659. smalltalk.TagBrush);
  660. smalltalk.addMethod(
  661. '_createTextNodeFor_',
  662. smalltalk.method({
  663. selector: 'createTextNodeFor:',
  664. category: 'private',
  665. fn: function (aString){
  666. var self=this;
  667. return (function(){return document.createTextNode(String(aString))})();
  668. return self;},
  669. source: unescape('createTextNodeFor%3A%20aString%0A%20%20%20%20%5E%7B%27return%20document.createTextNode%28String%28aString%29%29%27%7D%0A')}),
  670. smalltalk.TagBrush);
  671. smalltalk.addMethod(
  672. '_fromString_canvas_',
  673. smalltalk.method({
  674. selector: 'fromString:canvas:',
  675. category: 'instance creation',
  676. fn: function (aString, aCanvas){
  677. var self=this;
  678. return (function($rec){$rec._initializeFromString_canvas_(aString,aCanvas);return $rec._yourself();})(self._new());
  679. return self;},
  680. source: unescape('fromString%3A%20aString%20canvas%3A%20aCanvas%0A%20%20%20%20%5Eself%20new%0A%09initializeFromString%3A%20aString%20canvas%3A%20aCanvas%3B%0A%09yourself%0A')}),
  681. smalltalk.TagBrush.klass);
  682. smalltalk.addClass('Widget', smalltalk.Object, ['root'], 'Canvas');
  683. smalltalk.addMethod(
  684. '_root',
  685. smalltalk.method({
  686. selector: 'root',
  687. category: 'accessing',
  688. fn: function (){
  689. var self=this;
  690. return self['@root'];
  691. return self;},
  692. source: unescape('root%0A%20%20%20%20%5Eroot%0A')}),
  693. smalltalk.Widget);
  694. smalltalk.addMethod(
  695. '_appendToBrush_',
  696. smalltalk.method({
  697. selector: 'appendToBrush:',
  698. category: 'adding',
  699. fn: function (aTagBrush){
  700. var self=this;
  701. self._appendToJQuery_(aTagBrush._asJQuery());
  702. return self;},
  703. source: unescape('appendToBrush%3A%20aTagBrush%0A%20%20%20%20self%20appendToJQuery%3A%20aTagBrush%20asJQuery%0A')}),
  704. smalltalk.Widget);
  705. smalltalk.addMethod(
  706. '_appendToJQuery_',
  707. smalltalk.method({
  708. selector: 'appendToJQuery:',
  709. category: 'adding',
  710. fn: function (aJQuery){
  711. var self=this;
  712. self._render();
  713. aJQuery._append_(self._root()._asJQuery());
  714. return self;},
  715. source: unescape('appendToJQuery%3A%20aJQuery%0A%20%20%20%20self%20render.%0A%20%20%20%20aJQuery%20append%3A%20self%20root%20asJQuery%0A')}),
  716. smalltalk.Widget);
  717. smalltalk.addMethod(
  718. '_alert_',
  719. smalltalk.method({
  720. selector: 'alert:',
  721. category: 'actions',
  722. fn: function (aString){
  723. var self=this;
  724. (function(){alert(aString)})();
  725. return self;},
  726. source: unescape('alert%3A%20aString%0A%20%20%20%20%7B%27alert%28aString%29%27%7D%0A')}),
  727. smalltalk.Widget);
  728. smalltalk.addMethod(
  729. '_confirm_',
  730. smalltalk.method({
  731. selector: 'confirm:',
  732. category: 'actions',
  733. fn: function (aString){
  734. var self=this;
  735. return (function(){return window.confirm(aString)})();
  736. return self;},
  737. source: unescape('confirm%3A%20aString%0A%20%20%20%20%5E%7B%27return%20window.confirm%28aString%29%27%7D%0A')}),
  738. smalltalk.Widget);
  739. smalltalk.addMethod(
  740. '_prompt_',
  741. smalltalk.method({
  742. selector: 'prompt:',
  743. category: 'actions',
  744. fn: function (aString){
  745. var self=this;
  746. return self._prompt_default_(aString,"");
  747. return self;},
  748. source: unescape('prompt%3A%20aString%0A%20%20%20%20%5Eself%20prompt%3A%20aString%20default%3A%20%27%27%0A')}),
  749. smalltalk.Widget);
  750. smalltalk.addMethod(
  751. '_prompt_default_',
  752. smalltalk.method({
  753. selector: 'prompt:default:',
  754. category: 'actions',
  755. fn: function (aString, anotherString){
  756. var self=this;
  757. return (function(){return window.prompt(aString, anotherString)})();
  758. return self;},
  759. source: unescape('prompt%3A%20aString%20default%3A%20anotherString%0A%20%20%20%20%5E%7B%27return%20window.prompt%28aString%2C%20anotherString%29%27%7D%0A')}),
  760. smalltalk.Widget);
  761. smalltalk.addMethod(
  762. '_update',
  763. smalltalk.method({
  764. selector: 'update',
  765. category: 'actions',
  766. fn: function (){
  767. var self=this;
  768. var canvas=nil;
  769. canvas=smalltalk.HTMLCanvas._new();
  770. canvas._root_(self._root());
  771. self._root()._asJQuery()._empty();
  772. self._renderOn_(canvas);
  773. return self;},
  774. source: unescape('update%0A%20%20%20%20%7C%20canvas%20%7C%0A%20%20%20%20canvas%20%3A%3D%20HTMLCanvas%20new.%0A%20%20%20%20canvas%20root%3A%20self%20root.%0A%20%20%20%20self%20root%20asJQuery%20empty.%0A%20%20%20%20self%20renderOn%3A%20canvas%0A')}),
  775. smalltalk.Widget);
  776. smalltalk.addMethod(
  777. '_render',
  778. smalltalk.method({
  779. selector: 'render',
  780. category: 'rendering',
  781. fn: function (){
  782. var self=this;
  783. var canvas=nil;
  784. canvas=smalltalk.HTMLCanvas._new();
  785. self['@root']=canvas._root();
  786. self._renderOn_(canvas);
  787. return self;},
  788. source: unescape('render%0A%20%20%20%20%7C%20canvas%20%7C%0A%20%20%20%20canvas%20%3A%3D%20HTMLCanvas%20new.%0A%20%20%20%20root%20%3A%3D%20canvas%20root.%0A%20%20%20%20self%20renderOn%3A%20canvas%0A')}),
  789. smalltalk.Widget);
  790. smalltalk.addMethod(
  791. '_renderOn_',
  792. smalltalk.method({
  793. selector: 'renderOn:',
  794. category: 'rendering',
  795. fn: function (html){
  796. var self=this;
  797. self;
  798. return self;},
  799. source: unescape('renderOn%3A%20html%0A%20%20%20%20self%0A')}),
  800. smalltalk.Widget);
  801. smalltalk.addClass('Counter', smalltalk.Widget, ['count'], 'Canvas');
  802. smalltalk.addMethod(
  803. '_initialize',
  804. smalltalk.method({
  805. selector: 'initialize',
  806. category: 'initialization',
  807. fn: function (){
  808. var self=this;
  809. self.klass.superclass.fn.prototype['_initialize'].apply(self, []);
  810. self['@count']=(0);
  811. return self;},
  812. source: unescape('initialize%0A%20%20%20%20super%20initialize.%0A%20%20%20%20count%20%3A%3D%200%0A')}),
  813. smalltalk.Counter);
  814. smalltalk.addMethod(
  815. '_renderOn_',
  816. smalltalk.method({
  817. selector: 'renderOn:',
  818. category: 'rendering',
  819. fn: function (html){
  820. var self=this;
  821. html._h1()._with_(self['@count']._asString());
  822. (function($rec){$rec._with_(unescape("++"));return $rec._onClick_((function(){return self._increase();}));})(html._button());
  823. (function($rec){$rec._with_(unescape("--"));return $rec._onClick_((function(){return self._decrease();}));})(html._button());
  824. return self;},
  825. source: unescape('renderOn%3A%20html%0A%20%20%20%20html%20h1%20with%3A%20count%20asString.%0A%20%20%20%20html%20button%0A%09with%3A%20%27++%27%3B%0A%09onClick%3A%20%5Bself%20increase%5D.%0A%20%20%20%20html%20button%0A%09with%3A%20%27--%27%3B%0A%09onClick%3A%20%5Bself%20decrease%5D%0A')}),
  826. smalltalk.Counter);
  827. smalltalk.addMethod(
  828. '_increase',
  829. smalltalk.method({
  830. selector: 'increase',
  831. category: 'actions',
  832. fn: function (){
  833. var self=this;
  834. self['@count']=self['@count'].__plus((1));
  835. self._update();
  836. return self;},
  837. source: unescape('increase%0A%20%20%20%20count%20%3A%3D%20count%20+%201.%0A%20%20%20%20self%20update%0A')}),
  838. smalltalk.Counter);
  839. smalltalk.addMethod(
  840. '_decrease',
  841. smalltalk.method({
  842. selector: 'decrease',
  843. category: 'actions',
  844. fn: function (){
  845. var self=this;
  846. self['@count']=self['@count'].__minus((1));
  847. self._update();
  848. return self;},
  849. source: unescape('decrease%0A%20%20%20%20count%20%3A%3D%20count%20-%201.%0A%20%20%20%20self%20update%0A')}),
  850. smalltalk.Counter);