Canvas-Snippet.js 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  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. var snippet;
  11. return smalltalk.withContext(function($ctx1) { 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. snippet=_st(anAssociation)._value();
  21. _st(_st((smalltalk.ClassBuilder || ClassBuilder))._new())._installMethod_forClass_category_(_st(_st((function(htmlReceiver){
  22. return smalltalk.withContext(function($ctx2) { return _st(htmlReceiver)._snip_(snippet);
  23. }, function($ctx2) {$ctx2.fillBlock({htmlReceiver:htmlReceiver},$ctx1)})}))._currySelf())._asCompiledMethod_(_st(anAssociation)._key()),(smalltalk.HTMLCanvas || HTMLCanvas),"**snippets");
  24. return self}, function($ctx1) {$ctx1.fill(self,"addSnippet:",{anAssociation:anAssociation,snippet:snippet}, smalltalk.HtmlSnippet)})},
  25. args: ["anAssociation"],
  26. source: "addSnippet: anAssociation\x0a\x09| snippet |\x0a\x09(snippets ifNil: [ snippets := #{} ]) add: anAssociation.\x0a snippet := anAssociation value.\x0a ClassBuilder new\x0a \x09installMethod: ([ :htmlReceiver | htmlReceiver snip: snippet ] currySelf asCompiledMethod: anAssociation key)\x0a forClass: HTMLCanvas\x0a category: '**snippets'",
  27. messageSends: ["add:", "ifNil:", "value", "installMethod:forClass:category:", "asCompiledMethod:", "key", "currySelf", "snip:", "new"],
  28. referencedClasses: ["HTMLCanvas", "ClassBuilder"]
  29. }),
  30. smalltalk.HtmlSnippet);
  31. smalltalk.addMethod(
  32. "_addSnippets_",
  33. smalltalk.method({
  34. selector: "addSnippets:",
  35. category: 'accessing',
  36. fn: function (aCollection){
  37. var self=this;
  38. return smalltalk.withContext(function($ctx1) {
  39. _st(aCollection)._associationsDo_((function(each){
  40. return smalltalk.withContext(function($ctx2) {
  41. return _st(self)._addSnippet_(each);
  42. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}));
  43. return self}, function($ctx1) {$ctx1.fill(self,"addSnippets:",{aCollection:aCollection}, smalltalk.HtmlSnippet)})},
  44. args: ["aCollection"],
  45. source: "addSnippets: aCollection\x0a\x09aCollection associationsDo: [ :each | self addSnippet: each ]\x0a",
  46. messageSends: ["associationsDo:", "addSnippet:"],
  47. referencedClasses: []
  48. }),
  49. smalltalk.HtmlSnippet);
  50. smalltalk.addMethod(
  51. "_at_",
  52. smalltalk.method({
  53. selector: "at:",
  54. category: 'accessing',
  55. fn: function (aString){
  56. var self=this;
  57. return smalltalk.withContext(function($ctx1) {
  58. var $1;
  59. $1=_st(self["@snippets"])._at_(aString);
  60. return $1;
  61. }, function($ctx1) {$ctx1.fill(self,"at:",{aString:aString}, smalltalk.HtmlSnippet)})},
  62. args: ["aString"],
  63. source: "at: aString\x0a\x09^ snippets at: aString",
  64. messageSends: ["at:"],
  65. referencedClasses: []
  66. }),
  67. smalltalk.HtmlSnippet);
  68. smalltalk.addMethod(
  69. "_at_ifAbsent_",
  70. smalltalk.method({
  71. selector: "at:ifAbsent:",
  72. category: 'accessing',
  73. fn: function (aString,aBlock){
  74. var self=this;
  75. return smalltalk.withContext(function($ctx1) {
  76. var $1;
  77. $1=_st(self["@snippets"])._at_ifAbsent_(aString,aBlock);
  78. return $1;
  79. }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aString:aString,aBlock:aBlock}, smalltalk.HtmlSnippet)})},
  80. args: ["aString", "aBlock"],
  81. source: "at: aString ifAbsent: aBlock\x0a\x09^ snippets at: aString ifAbsent: aBlock",
  82. messageSends: ["at:ifAbsent:"],
  83. referencedClasses: []
  84. }),
  85. smalltalk.HtmlSnippet);
  86. smalltalk.HtmlSnippet.klass.iVarNames = ['current'];
  87. smalltalk.addMethod(
  88. "_current",
  89. smalltalk.method({
  90. selector: "current",
  91. category: 'instance creation',
  92. fn: function (){
  93. var self=this;
  94. return smalltalk.withContext(function($ctx1) {
  95. var $2,$3,$4,$1;
  96. $2=self["@current"];
  97. if(($receiver = $2) == nil || $receiver == undefined){
  98. $3=_st(self)._new();
  99. _st($3)._addSnippets_(_st(self)._digFromJQuery_(_st(document)._asJQuery()));
  100. $4=_st($3)._yourself();
  101. self["@current"]=$4;
  102. $1=self["@current"];
  103. } else {
  104. $1=$2;
  105. };
  106. return $1;
  107. }, function($ctx1) {$ctx1.fill(self,"current",{}, smalltalk.HtmlSnippet.klass)})},
  108. args: [],
  109. source: "current\x0a\x09^ current ifNil: [\x0a\x09\x09current := self new addSnippets: (self digFromJQuery: document asJQuery); yourself ]",
  110. messageSends: ["ifNil:", "addSnippets:", "digFromJQuery:", "asJQuery", "new", "yourself"],
  111. referencedClasses: []
  112. }),
  113. smalltalk.HtmlSnippet.klass);
  114. smalltalk.addMethod(
  115. "_digFromJQuery_",
  116. smalltalk.method({
  117. selector: "digFromJQuery:",
  118. category: 'action',
  119. fn: function (aJQuery){
  120. var self=this;
  121. var result;
  122. return smalltalk.withContext(function($ctx1) {
  123. var $1,$2,$3;
  124. result=smalltalk.HashedCollection._fromPairs_([]);
  125. _st(_st(_st("[data-snippet]")._asJQuery())._toArray())._do_((function(each){
  126. var jq,name;
  127. return smalltalk.withContext(function($ctx2) {
  128. jq=_st(each)._asJQuery();
  129. jq;
  130. name=_st(jq)._attr_("data-snippet");
  131. name;
  132. $1=_st(name).__eq("*");
  133. if(! smalltalk.assert($1)){
  134. $2=_st(_st("^\x5c*")._asRegexp())._test_(name);
  135. if(smalltalk.assert($2)){
  136. name=_st(name)._allButFirst();
  137. name;
  138. _st(jq)._attr_put_("data-snippet","*");
  139. } else {
  140. _st(jq)._removeAttr_("data-snippet");
  141. };
  142. return _st(result)._at_put_(name,_st(_st(jq)._detach())._get_((0)));
  143. };
  144. }, function($ctx2) {$ctx2.fillBlock({each:each,jq:jq,name:name},$ctx1)})}));
  145. $3=result;
  146. return $3;
  147. }, function($ctx1) {$ctx1.fill(self,"digFromJQuery:",{aJQuery:aJQuery,result:result}, smalltalk.HtmlSnippet.klass)})},
  148. args: ["aJQuery"],
  149. 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",
  150. messageSends: ["do:", "asJQuery", "attr:", "ifFalse:", "ifTrue:ifFalse:", "allButFirst", "attr:put:", "removeAttr:", "test:", "asRegexp", "at:put:", "get:", "detach", "=", "toArray"],
  151. referencedClasses: []
  152. }),
  153. smalltalk.HtmlSnippet.klass);
  154. smalltalk.addMethod(
  155. "_asSnippet",
  156. smalltalk.method({
  157. selector: "asSnippet",
  158. category: '*Canvas-Snippet',
  159. fn: function (){
  160. var self=this;
  161. return smalltalk.withContext(function($ctx1) {
  162. var $1;
  163. $1=_st(_st((smalltalk.HtmlSnippet || HtmlSnippet))._current())._at_(_st(self)._asString());
  164. return $1;
  165. }, function($ctx1) {$ctx1.fill(self,"asSnippet",{}, smalltalk.CharacterArray)})},
  166. args: [],
  167. source: "asSnippet\x0a\x09^ HtmlSnippet current at: self asString",
  168. messageSends: ["at:", "asString", "current"],
  169. referencedClasses: ["HtmlSnippet"]
  170. }),
  171. smalltalk.CharacterArray);
  172. smalltalk.addMethod(
  173. "_snip_",
  174. smalltalk.method({
  175. selector: "snip:",
  176. category: '*Canvas-Snippet',
  177. fn: function (anElement){
  178. var self=this;
  179. var clone,caret;
  180. return smalltalk.withContext(function($ctx1) { var $1,$2;
  181. clone=_st(_st(anElement)._asJQuery())._clone();
  182. _st(self)._with_(_st((smalltalk.TagBrush || TagBrush))._fromJQuery_canvas_(clone,self));
  183. caret=_st(clone)._find_("[data-snippet=\x22*\x22]");
  184. $1=_st(_st(caret)._toArray())._isEmpty();
  185. if(smalltalk.assert($1)){
  186. caret=clone;
  187. caret;
  188. };
  189. $2=_st((smalltalk.TagBrush || TagBrush))._fromJQuery_canvas_(_st(caret)._removeAttr_("data-snippet"),self);
  190. return $2;
  191. }, function($ctx1) {$ctx1.fill(self,"snip:",{anElement:anElement,clone:clone,caret:caret}, smalltalk.HTMLCanvas)})},
  192. args: ["anElement"],
  193. 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",
  194. messageSends: ["clone", "asJQuery", "with:", "fromJQuery:canvas:", "find:", "ifTrue:", "isEmpty", "toArray", "removeAttr:"],
  195. referencedClasses: ["TagBrush"]
  196. }),
  197. smalltalk.HTMLCanvas);