Canvas-Snippet.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. smalltalk.addPackage('Canvas-Snippet', {});
  2. smalltalk.addClass('HtmlSnippet', smalltalk.Object, ['snippets'], 'Canvas-Snippet');
  3. smalltalk.addMethod(
  4. "_addSnippet_",
  5. smalltalk.method({
  6. selector: "addSnippet:",
  7. category: 'accessing',
  8. fn: function (anAssociation){
  9. var self=this;
  10. return smalltalk.withContext(function($ctx1) {
  11. var $2,$1;
  12. $2=self["@snippets"];
  13. if(($receiver = $2) == nil || $receiver == undefined){
  14. self["@snippets"]=smalltalk.HashedCollection._fromPairs_([]);
  15. $1=self["@snippets"];
  16. } else {
  17. $1=$2;
  18. };
  19. _st($1)._add_(anAssociation);
  20. return self}, function($ctx1) {$ctx1.fill(self,"addSnippet:",{anAssociation:anAssociation}, smalltalk.HtmlSnippet)})},
  21. args: ["anAssociation"],
  22. source: "addSnippet: anAssociation\x0a\x09(snippets ifNil: [ snippets := #{} ]) add: anAssociation",
  23. messageSends: ["add:", "ifNil:"],
  24. referencedClasses: []
  25. }),
  26. smalltalk.HtmlSnippet);
  27. smalltalk.addMethod(
  28. "_addSnippets_",
  29. smalltalk.method({
  30. selector: "addSnippets:",
  31. category: 'accessing',
  32. fn: function (aCollection){
  33. var self=this;
  34. return smalltalk.withContext(function($ctx1) {
  35. _st(aCollection)._associationsDo_((function(each){
  36. return smalltalk.withContext(function($ctx2) {
  37. return _st(self)._addSnippet_(each);
  38. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}));
  39. return self}, function($ctx1) {$ctx1.fill(self,"addSnippets:",{aCollection:aCollection}, smalltalk.HtmlSnippet)})},
  40. args: ["aCollection"],
  41. source: "addSnippets: aCollection\x0a\x09aCollection associationsDo: [ :each | self addSnippet: each ]\x0a",
  42. messageSends: ["associationsDo:", "addSnippet:"],
  43. referencedClasses: []
  44. }),
  45. smalltalk.HtmlSnippet);
  46. smalltalk.addMethod(
  47. "_at_",
  48. smalltalk.method({
  49. selector: "at:",
  50. category: 'accessing',
  51. fn: function (aString){
  52. var self=this;
  53. return smalltalk.withContext(function($ctx1) {
  54. var $1;
  55. $1=_st(self["@snippets"])._at_(aString);
  56. return $1;
  57. }, function($ctx1) {$ctx1.fill(self,"at:",{aString:aString}, smalltalk.HtmlSnippet)})},
  58. args: ["aString"],
  59. source: "at: aString\x0a\x09^ snippets at: aString",
  60. messageSends: ["at:"],
  61. referencedClasses: []
  62. }),
  63. smalltalk.HtmlSnippet);
  64. smalltalk.addMethod(
  65. "_at_ifAbsent_",
  66. smalltalk.method({
  67. selector: "at:ifAbsent:",
  68. category: 'accessing',
  69. fn: function (aString,aBlock){
  70. var self=this;
  71. return smalltalk.withContext(function($ctx1) {
  72. var $1;
  73. $1=_st(self["@snippets"])._at_ifAbsent_(aString,aBlock);
  74. return $1;
  75. }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aString:aString,aBlock:aBlock}, smalltalk.HtmlSnippet)})},
  76. args: ["aString", "aBlock"],
  77. source: "at: aString ifAbsent: aBlock\x0a\x09^ snippets at: aString ifAbsent: aBlock",
  78. messageSends: ["at:ifAbsent:"],
  79. referencedClasses: []
  80. }),
  81. smalltalk.HtmlSnippet);
  82. smalltalk.HtmlSnippet.klass.iVarNames = ['current'];
  83. smalltalk.addMethod(
  84. "_current",
  85. smalltalk.method({
  86. selector: "current",
  87. category: 'instance creation',
  88. fn: function (){
  89. var self=this;
  90. return smalltalk.withContext(function($ctx1) {
  91. var $2,$3,$4,$1;
  92. $2=self["@current"];
  93. if(($receiver = $2) == nil || $receiver == undefined){
  94. $3=_st(self)._new();
  95. _st($3)._addSnippets_(_st(self)._digFromJQuery_(_st(document)._asJQuery()));
  96. $4=_st($3)._yourself();
  97. self["@current"]=$4;
  98. $1=self["@current"];
  99. } else {
  100. $1=$2;
  101. };
  102. return $1;
  103. }, function($ctx1) {$ctx1.fill(self,"current",{}, smalltalk.HtmlSnippet.klass)})},
  104. args: [],
  105. source: "current\x0a\x09^ current ifNil: [\x0a\x09\x09current := self new addSnippets: (self digFromJQuery: document asJQuery); yourself ]",
  106. messageSends: ["ifNil:", "addSnippets:", "digFromJQuery:", "asJQuery", "new", "yourself"],
  107. referencedClasses: []
  108. }),
  109. smalltalk.HtmlSnippet.klass);
  110. smalltalk.addMethod(
  111. "_digFromJQuery_",
  112. smalltalk.method({
  113. selector: "digFromJQuery:",
  114. category: 'action',
  115. fn: function (aJQuery){
  116. var self=this;
  117. var result;
  118. return smalltalk.withContext(function($ctx1) {
  119. var $1,$2,$3;
  120. result=smalltalk.HashedCollection._fromPairs_([]);
  121. _st(_st(_st("[data-snippet]")._asJQuery())._toArray())._do_((function(each){
  122. var jq,name;
  123. return smalltalk.withContext(function($ctx2) {
  124. jq=_st(each)._asJQuery();
  125. jq;
  126. name=_st(jq)._attr_("data-snippet");
  127. name;
  128. $1=_st(name).__eq("*");
  129. if(! smalltalk.assert($1)){
  130. $2=_st(_st("^\x5c*")._asRegexp())._test_(name);
  131. if(smalltalk.assert($2)){
  132. name=_st(name)._allButFirst();
  133. name;
  134. _st(jq)._attr_put_("data-snippet","*");
  135. } else {
  136. _st(jq)._removeAttr_("data-snippet");
  137. };
  138. return _st(result)._at_put_(name,_st(_st(jq)._detach())._get_((0)));
  139. };
  140. }, function($ctx2) {$ctx2.fillBlock({each:each,jq:jq,name:name},$ctx1)})}));
  141. $3=result;
  142. return $3;
  143. }, function($ctx1) {$ctx1.fill(self,"digFromJQuery:",{aJQuery:aJQuery,result:result}, smalltalk.HtmlSnippet.klass)})},
  144. args: ["aJQuery"],
  145. source: "digFromJQuery: aJQuery\x0a\x09\x22Finds and takes out all snippets out of aJQuery\x22\x0a | result |\x0a result := #{}.\x0a\x09'[data-snippet]' asJQuery toArray do: [ :each |\x0a \x09| jq name |\x0a jq := each asJQuery.\x0a name := jq attr: 'data-snippet'.\x0a name = '*' ifFalse: [\x0a \x09('^\x5c*' asRegexp test: name) ifTrue: [ name := name allButFirst. jq attr: 'data-snippet' put: '*' ]\x0a \x09\x09ifFalse: [ jq removeAttr: 'data-snippet' ].\x0a result at: name put: (jq detach get: 0) ]].\x0a\x09^result",
  146. messageSends: ["do:", "asJQuery", "attr:", "ifFalse:", "ifTrue:ifFalse:", "allButFirst", "attr:put:", "removeAttr:", "test:", "asRegexp", "at:put:", "get:", "detach", "=", "toArray"],
  147. referencedClasses: []
  148. }),
  149. smalltalk.HtmlSnippet.klass);
  150. smalltalk.addMethod(
  151. "_asSnippet",
  152. smalltalk.method({
  153. selector: "asSnippet",
  154. category: '*Canvas-Snippet',
  155. fn: function (){
  156. var self=this;
  157. return smalltalk.withContext(function($ctx1) {
  158. var $1;
  159. $1=_st(_st((smalltalk.HtmlSnippet || HtmlSnippet))._current())._at_(_st(self)._asString());
  160. return $1;
  161. }, function($ctx1) {$ctx1.fill(self,"asSnippet",{}, smalltalk.CharacterArray)})},
  162. args: [],
  163. source: "asSnippet\x0a\x09^ HtmlSnippet current at: self asString",
  164. messageSends: ["at:", "asString", "current"],
  165. referencedClasses: ["HtmlSnippet"]
  166. }),
  167. smalltalk.CharacterArray);
  168. smalltalk.addMethod(
  169. "_doesNotUnderstand_",
  170. smalltalk.method({
  171. selector: "doesNotUnderstand:",
  172. category: '*Canvas-Snippet',
  173. fn: function (aMessage){
  174. var self=this;
  175. var snippet;
  176. return smalltalk.withContext(function($ctx1) {
  177. var $1,$2,$3,$4;
  178. var $early={};
  179. try {
  180. $1=_st(_st(aMessage)._arguments())._isEmpty();
  181. if(! smalltalk.assert($1)){
  182. $2=smalltalk.Object.fn.prototype._doesNotUnderstand_.apply(_st(self), [aMessage]);
  183. return $2;
  184. };
  185. snippet=_st(_st((smalltalk.HtmlSnippet || HtmlSnippet))._current())._at_ifAbsent_(_st(aMessage)._selector(),(function(){
  186. return smalltalk.withContext(function($ctx2) {
  187. $3=smalltalk.Object.fn.prototype._doesNotUnderstand_.apply(_st(self), [aMessage]);
  188. throw $early=[$3];
  189. }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}));
  190. $4=_st(self)._snip_(snippet);
  191. return $4;
  192. }
  193. catch(e) {if(e===$early)return e[0]; throw e}
  194. }, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage,snippet:snippet}, smalltalk.HTMLCanvas)})},
  195. args: ["aMessage"],
  196. source: "doesNotUnderstand: aMessage\x0a\x09| snippet |\x0a\x09aMessage arguments isEmpty ifFalse: [ ^super doesNotUnderstand: aMessage ].\x0a snippet := HtmlSnippet current at: aMessage selector ifAbsent: [ ^super doesNotUnderstand: aMessage ].\x0a ^ self snip: snippet",
  197. messageSends: ["ifFalse:", "doesNotUnderstand:", "isEmpty", "arguments", "at:ifAbsent:", "selector", "current", "snip:"],
  198. referencedClasses: ["HtmlSnippet"]
  199. }),
  200. smalltalk.HTMLCanvas);
  201. smalltalk.addMethod(
  202. "_snip_",
  203. smalltalk.method({
  204. selector: "snip:",
  205. category: '*Canvas-Snippet',
  206. fn: function (anElement){
  207. var self=this;
  208. var clone,caret;
  209. return smalltalk.withContext(function($ctx1) { var $1,$2;
  210. clone=_st(_st(anElement)._asJQuery())._clone();
  211. _st(self)._with_(_st((smalltalk.TagBrush || TagBrush))._fromJQuery_canvas_(clone,self));
  212. caret=_st(clone)._find_("[data-snippet=\x22*\x22]");
  213. $1=_st(_st(caret)._toArray())._isEmpty();
  214. if(smalltalk.assert($1)){
  215. caret=clone;
  216. caret;
  217. };
  218. $2=_st((smalltalk.TagBrush || TagBrush))._fromJQuery_canvas_(_st(caret)._removeAttr_("data-snippet"),self);
  219. return $2;
  220. }, function($ctx1) {$ctx1.fill(self,"snip:",{anElement:anElement,clone:clone,caret:caret}, smalltalk.HTMLCanvas)})},
  221. args: ["anElement"],
  222. source: "snip: anElement\x0a\x09\x22Adds clone of anElement, finds [data-snippet=\x22\x22*\x22\x22] subelement\x0a and returns TagBrush as if that subelement was just added.\x0a \x0a Use with asSnippet -- (html snip: #mySnip asSnippet) with: [...]\x22\x0a | clone caret |\x0a clone := anElement asJQuery clone.\x0a self with: (TagBrush fromJQuery: clone canvas: self).\x0a caret := clone find: '[data-snippet=\x22*\x22]'.\x0a caret toArray isEmpty ifTrue: [ caret := clone ].\x0a ^TagBrush fromJQuery: (caret removeAttr: 'data-snippet') canvas: self",
  223. messageSends: ["clone", "asJQuery", "with:", "fromJQuery:canvas:", "find:", "ifTrue:", "isEmpty", "toArray", "removeAttr:"],
  224. referencedClasses: ["TagBrush"]
  225. }),
  226. smalltalk.HTMLCanvas);