snipt

Ctrl+h for KB shortcuts

JavaScript

frontend.php

<script type="text/javascript">
    app.controller('myController<?=$prop_id?>', ['$scope', function($scope) {

    	$scope.positions = <?=CUtil::PhpToJSObject($arPositions)?>;
		$scope.departments = <?=CUtil::PhpToJSObject($arDepartments)?>;

    	$scope.isChecked = function(value) {
    		var unchecked =  (typeof value == 'undefined') || (typeof value == 'boolean' && value === false);
    		return !unchecked;
    	};

    	$scope.hasChecked = function(item) {
    		var checked = item.checked;
    		if ($scope.isChecked(checked)) return true;

    		var cats = item.categories;
    		
    		for (var c in cats) {
    			var g = cats[c];
    			var checked = $scope.isChecked(g.checked);

    			if (checked) return true;

    			if (typeof g.categories == 'object') {
    				return $scope.hasChecked(g);
    			}
    		}

    		return false;
    	}

    	$scope.getCategoryByID = function(id, categories) {
    		var cat = false;

    		for (var index in categories) {
    			var category = categories[index];
    			
    			if (category.id == id) {
    				cat = category;
    			} else if (typeof category.categories != 'undefined') {
    				cat = $scope.getCategoryByID(id, category.categories);
    			}

    			if (cat) {
    				break;
    			}
			}

			return cat;
    	};

    	$scope.getCategory = function(id, name) {
    		var category = $scope.getCategoryByID(id, $scope[name]);
    		return category;
    	};

    	$scope.checkCategory = function(id, name, params) {
			var category = $scope.getCategory(id, name);

			if (category) {
				for (var p in params) {
					category[p] = params[p];
				}

				var categories = category.categories;

				if (typeof categories == 'object') {
					for (var index in categories) {
						var cat = categories[index];
						$scope.checkCategory(cat.id, name, params);
					}
				}
			}
    	};

    	$scope.checkItem = function(id, value) {
    		if (value === null) value = true;
    		if (typeof value != 'boolean') return;

    		$scope.checkCategory(id, 'positions', { 'checked' : value });
    		$scope.checkCategory(id, 'departments', { 'checked' : value });
    	};

    	$scope.showModal = function() {
    		$('#modal<?=$prop_id?>').modal().modal('show');
            return false;
    	}

    	$scope.showAll = function(jqx, jqxItems) {
    		for (var index in jqxItems) {
    			var item = jqxItems[index];
    			var elem = item.element;
    			$(elem).show();
    		}
    	}

    	$scope.hideAll = function(jqx, jqxItems) {
    		for (var index in jqxItems) {
    			var item = jqxItems[index];
    			var elem = item.element;
    			$(elem).hide();
    		}
    	}

    	$scope.showItem = function(jqx, item) {
			if (typeof item == 'undefined' || item == null) return;

			var elem = item.element;
			$(elem).show();

			if (item.level > 0) {
				var parentElement = item.parentElement;
				var parent = jqx.jqxTree('getItem', parentElement);
				$scope.showItem(jqx, parent);
			}
    	}

    	$scope.hideItem = function(jqx, item) {
			var elem = item.element;
			$(elem).hide();
    	}

    	$scope.filterItems = function(jqx, jqxItems, pattern) {
    		$scope.hideAll(jqx, jqxItems);

    		for (var index in jqxItems) {
    			var item = jqxItems[index];
    			
    			var text = item.label;
    			var result = text.search(pattern);

    			if (result >= 0) {
    				$scope.showItem(jqx, item);
    			}
    		}        		
    	}

    	$scope.search = function(selector, search) {
    		var jqx = $(selector);
    		var items = jqx.jqxTree('getItems');
    		var pattern = new RegExp(search, "i");

    		if (typeof search == 'undefined' || search == '') {
    			$scope.showAll(jqx, items);
    			return;
    		}

    		$scope.filterItems(jqx, items, pattern);
    	}

    	$scope.initPopup = function() {
    		$('.ui .label').each(function() {
        		var elem = $(this).find('.popup');
        		
        		if (elem.length > 0) {
        			elem = elem[0];
            		$(this).popup({
            			popup: elem
            		});
        		}
        	});
    	}

    	$scope.$watch('searchPosition', function(newVal) {
    		var selector = '#jqxTree-position<?=$prop_id?>';
    		$scope.search(selector, newVal);
    	});

    	$scope.$watch('searchDepartment', function(newVal) {
    		var selector = '#jqxTree-department<?=$prop_id?>';
    		$scope.search(selector, newVal);
    	});

    	angular.element(document).ready(function () {
	        $scope.initPopup();
            $('.edit-button').click(function() {
                return false;
            });
	    });
    }]);

	app.directive('semanticTab<?=$prop_id?>', function() {
		return function($scope, elem, attrs) {
			$(elem).tab();
		};
	});

	app.directive('jqxTree<?=$prop_id?>', [function() {
		return {
			restrict: 'A',
			scope: {
		      'model': '='
		    },
		    link: function($scope, elem, attrs) {
		    	$(document).ready(function() {
			    	$(elem).jqxTree({
			        	hasThreeStates: true,
			        	checkboxes: true,
			        	height: '300px'
			        })
			        .on('checkChange', function (event) {
					    var args = event.args;
					    var element = args.element;
					    var checked = args.checked;
					    var id = $(element).attr('item-id');
					    
					    $scope.$apply(function() {
				            $scope.$parent.checkItem(id, checked);
				            
				            // delay for init popup
				            setTimeout(function() {
				            	$scope.$parent.initPopup();
				            }, 500);
				        });
					})
					.css('visibility', 'visible');
		    	});
		    }
		}
	}]);
</script>
https://snipt.net/embed/5dc2964d4bb1309d7566a1984ade9009/
/raw/5dc2964d4bb1309d7566a1984ade9009/
5dc2964d4bb1309d7566a1984ade9009
js
JavaScript
221
2019-07-15T20:59:37
True
False
False
Jan 17, 2016 at 11:11 PM
/api/public/snipt/143624/
frontendphp
<table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><a href="#L-1"> 1</a> <a href="#L-2"> 2</a> <a href="#L-3"> 3</a> <a href="#L-4"> 4</a> <a href="#L-5"> 5</a> <a href="#L-6"> 6</a> <a href="#L-7"> 7</a> <a href="#L-8"> 8</a> <a href="#L-9"> 9</a> <a href="#L-10"> 10</a> <a href="#L-11"> 11</a> <a href="#L-12"> 12</a> <a href="#L-13"> 13</a> <a href="#L-14"> 14</a> <a href="#L-15"> 15</a> <a href="#L-16"> 16</a> <a href="#L-17"> 17</a> <a href="#L-18"> 18</a> <a href="#L-19"> 19</a> <a href="#L-20"> 20</a> <a href="#L-21"> 21</a> <a href="#L-22"> 22</a> <a href="#L-23"> 23</a> <a href="#L-24"> 24</a> <a href="#L-25"> 25</a> <a href="#L-26"> 26</a> <a href="#L-27"> 27</a> <a href="#L-28"> 28</a> <a href="#L-29"> 29</a> <a href="#L-30"> 30</a> <a href="#L-31"> 31</a> <a href="#L-32"> 32</a> <a href="#L-33"> 33</a> <a href="#L-34"> 34</a> <a href="#L-35"> 35</a> <a href="#L-36"> 36</a> <a href="#L-37"> 37</a> <a href="#L-38"> 38</a> <a href="#L-39"> 39</a> <a href="#L-40"> 40</a> <a href="#L-41"> 41</a> <a href="#L-42"> 42</a> <a href="#L-43"> 43</a> <a href="#L-44"> 44</a> <a href="#L-45"> 45</a> <a href="#L-46"> 46</a> <a href="#L-47"> 47</a> <a href="#L-48"> 48</a> <a href="#L-49"> 49</a> <a href="#L-50"> 50</a> <a href="#L-51"> 51</a> <a href="#L-52"> 52</a> <a href="#L-53"> 53</a> <a href="#L-54"> 54</a> <a href="#L-55"> 55</a> <a href="#L-56"> 56</a> <a href="#L-57"> 57</a> <a href="#L-58"> 58</a> <a href="#L-59"> 59</a> <a href="#L-60"> 60</a> <a href="#L-61"> 61</a> <a href="#L-62"> 62</a> <a href="#L-63"> 63</a> <a href="#L-64"> 64</a> <a href="#L-65"> 65</a> <a href="#L-66"> 66</a> <a href="#L-67"> 67</a> <a href="#L-68"> 68</a> <a href="#L-69"> 69</a> <a href="#L-70"> 70</a> <a href="#L-71"> 71</a> <a href="#L-72"> 72</a> <a href="#L-73"> 73</a> <a href="#L-74"> 74</a> <a href="#L-75"> 75</a> <a href="#L-76"> 76</a> <a href="#L-77"> 77</a> <a href="#L-78"> 78</a> <a href="#L-79"> 79</a> <a href="#L-80"> 80</a> <a href="#L-81"> 81</a> <a href="#L-82"> 82</a> <a href="#L-83"> 83</a> <a href="#L-84"> 84</a> <a href="#L-85"> 85</a> <a href="#L-86"> 86</a> <a href="#L-87"> 87</a> <a href="#L-88"> 88</a> <a href="#L-89"> 89</a> <a href="#L-90"> 90</a> <a href="#L-91"> 91</a> <a href="#L-92"> 92</a> <a href="#L-93"> 93</a> <a href="#L-94"> 94</a> <a href="#L-95"> 95</a> <a href="#L-96"> 96</a> <a href="#L-97"> 97</a> <a href="#L-98"> 98</a> <a href="#L-99"> 99</a> <a href="#L-100">100</a> <a href="#L-101">101</a> <a href="#L-102">102</a> <a href="#L-103">103</a> <a href="#L-104">104</a> <a href="#L-105">105</a> <a href="#L-106">106</a> <a href="#L-107">107</a> <a href="#L-108">108</a> <a href="#L-109">109</a> <a href="#L-110">110</a> <a href="#L-111">111</a> <a href="#L-112">112</a> <a href="#L-113">113</a> <a href="#L-114">114</a> <a href="#L-115">115</a> <a href="#L-116">116</a> <a href="#L-117">117</a> <a href="#L-118">118</a> <a href="#L-119">119</a> <a href="#L-120">120</a> <a href="#L-121">121</a> <a href="#L-122">122</a> <a href="#L-123">123</a> <a href="#L-124">124</a> <a href="#L-125">125</a> <a href="#L-126">126</a> <a href="#L-127">127</a> <a href="#L-128">128</a> <a href="#L-129">129</a> <a href="#L-130">130</a> <a href="#L-131">131</a> <a href="#L-132">132</a> <a href="#L-133">133</a> <a href="#L-134">134</a> <a href="#L-135">135</a> <a href="#L-136">136</a> <a href="#L-137">137</a> <a href="#L-138">138</a> <a href="#L-139">139</a> <a href="#L-140">140</a> <a href="#L-141">141</a> <a href="#L-142">142</a> <a href="#L-143">143</a> <a href="#L-144">144</a> <a href="#L-145">145</a> <a href="#L-146">146</a> <a href="#L-147">147</a> <a href="#L-148">148</a> <a href="#L-149">149</a> <a href="#L-150">150</a> <a href="#L-151">151</a> <a href="#L-152">152</a> <a href="#L-153">153</a> <a href="#L-154">154</a> <a href="#L-155">155</a> <a href="#L-156">156</a> <a href="#L-157">157</a> <a href="#L-158">158</a> <a href="#L-159">159</a> <a href="#L-160">160</a> <a href="#L-161">161</a> <a href="#L-162">162</a> <a href="#L-163">163</a> <a href="#L-164">164</a> <a href="#L-165">165</a> <a href="#L-166">166</a> <a href="#L-167">167</a> <a href="#L-168">168</a> <a href="#L-169">169</a> <a href="#L-170">170</a> <a href="#L-171">171</a> <a href="#L-172">172</a> <a href="#L-173">173</a> <a href="#L-174">174</a> <a href="#L-175">175</a> <a href="#L-176">176</a> <a href="#L-177">177</a> <a href="#L-178">178</a> <a href="#L-179">179</a> <a href="#L-180">180</a> <a href="#L-181">181</a> <a href="#L-182">182</a> <a href="#L-183">183</a> <a href="#L-184">184</a> <a href="#L-185">185</a> <a href="#L-186">186</a> <a href="#L-187">187</a> <a href="#L-188">188</a> <a href="#L-189">189</a> <a href="#L-190">190</a> <a href="#L-191">191</a> <a href="#L-192">192</a> <a href="#L-193">193</a> <a href="#L-194">194</a> <a href="#L-195">195</a> <a href="#L-196">196</a> <a href="#L-197">197</a> <a href="#L-198">198</a> <a href="#L-199">199</a> <a href="#L-200">200</a> <a href="#L-201">201</a> <a href="#L-202">202</a> <a href="#L-203">203</a> <a href="#L-204">204</a> <a href="#L-205">205</a> <a href="#L-206">206</a> <a href="#L-207">207</a> <a href="#L-208">208</a> <a href="#L-209">209</a> <a href="#L-210">210</a> <a href="#L-211">211</a> <a href="#L-212">212</a> <a href="#L-213">213</a> <a href="#L-214">214</a> <a href="#L-215">215</a> <a href="#L-216">216</a> <a href="#L-217">217</a> <a href="#L-218">218</a> <a href="#L-219">219</a> <a href="#L-220">220</a> <a href="#L-221">221</a></pre></div></td><td class="code"><div class="highlight"><pre><span></span><span id="L-1"><a name="L-1"></a><span class="o">&lt;</span><span class="nx">script</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text/javascript&quot;</span><span class="o">&gt;</span> </span><span id="L-2"><a name="L-2"></a> <span class="nx">app</span><span class="p">.</span><span class="nx">controller</span><span class="p">(</span><span class="s1">&#39;myController&lt;?=$prop_id?&gt;&#39;</span><span class="p">,</span> <span class="p">[</span><span class="s1">&#39;$scope&#39;</span><span class="p">,</span> <span class="kd">function</span><span class="p">(</span><span class="nx">$scope</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-3"><a name="L-3"></a> </span><span id="L-4"><a name="L-4"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">positions</span> <span class="o">=</span> <span class="o">&lt;?=</span><span class="nx">CUtil</span><span class="o">::</span><span class="nx">PhpToJSObject</span><span class="p">(</span><span class="nx">$arPositions</span><span class="p">)</span><span class="o">?&gt;</span><span class="p">;</span> </span><span id="L-5"><a name="L-5"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">departments</span> <span class="o">=</span> <span class="o">&lt;?=</span><span class="nx">CUtil</span><span class="o">::</span><span class="nx">PhpToJSObject</span><span class="p">(</span><span class="nx">$arDepartments</span><span class="p">)</span><span class="o">?&gt;</span><span class="p">;</span> </span><span id="L-6"><a name="L-6"></a> </span><span id="L-7"><a name="L-7"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">isChecked</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">value</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-8"><a name="L-8"></a> <span class="kd">var</span> <span class="nx">unchecked</span> <span class="o">=</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">value</span> <span class="o">==</span> <span class="s1">&#39;undefined&#39;</span><span class="p">)</span> <span class="o">||</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">value</span> <span class="o">==</span> <span class="s1">&#39;boolean&#39;</span> <span class="o">&amp;&amp;</span> <span class="nx">value</span> <span class="o">===</span> <span class="kc">false</span><span class="p">);</span> </span><span id="L-9"><a name="L-9"></a> <span class="k">return</span> <span class="o">!</span><span class="nx">unchecked</span><span class="p">;</span> </span><span id="L-10"><a name="L-10"></a> <span class="p">};</span> </span><span id="L-11"><a name="L-11"></a> </span><span id="L-12"><a name="L-12"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">hasChecked</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">item</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-13"><a name="L-13"></a> <span class="kd">var</span> <span class="nx">checked</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">checked</span><span class="p">;</span> </span><span id="L-14"><a name="L-14"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">$scope</span><span class="p">.</span><span class="nx">isChecked</span><span class="p">(</span><span class="nx">checked</span><span class="p">))</span> <span class="k">return</span> <span class="kc">true</span><span class="p">;</span> </span><span id="L-15"><a name="L-15"></a> </span><span id="L-16"><a name="L-16"></a> <span class="kd">var</span> <span class="nx">cats</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">categories</span><span class="p">;</span> </span><span id="L-17"><a name="L-17"></a> </span><span id="L-18"><a name="L-18"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">c</span> <span class="k">in</span> <span class="nx">cats</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-19"><a name="L-19"></a> <span class="kd">var</span> <span class="nx">g</span> <span class="o">=</span> <span class="nx">cats</span><span class="p">[</span><span class="nx">c</span><span class="p">];</span> </span><span id="L-20"><a name="L-20"></a> <span class="kd">var</span> <span class="nx">checked</span> <span class="o">=</span> <span class="nx">$scope</span><span class="p">.</span><span class="nx">isChecked</span><span class="p">(</span><span class="nx">g</span><span class="p">.</span><span class="nx">checked</span><span class="p">);</span> </span><span id="L-21"><a name="L-21"></a> </span><span id="L-22"><a name="L-22"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">checked</span><span class="p">)</span> <span class="k">return</span> <span class="kc">true</span><span class="p">;</span> </span><span id="L-23"><a name="L-23"></a> </span><span id="L-24"><a name="L-24"></a> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">g</span><span class="p">.</span><span class="nx">categories</span> <span class="o">==</span> <span class="s1">&#39;object&#39;</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-25"><a name="L-25"></a> <span class="k">return</span> <span class="nx">$scope</span><span class="p">.</span><span class="nx">hasChecked</span><span class="p">(</span><span class="nx">g</span><span class="p">);</span> </span><span id="L-26"><a name="L-26"></a> <span class="p">}</span> </span><span id="L-27"><a name="L-27"></a> <span class="p">}</span> </span><span id="L-28"><a name="L-28"></a> </span><span id="L-29"><a name="L-29"></a> <span class="k">return</span> <span class="kc">false</span><span class="p">;</span> </span><span id="L-30"><a name="L-30"></a> <span class="p">}</span> </span><span id="L-31"><a name="L-31"></a> </span><span id="L-32"><a name="L-32"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">getCategoryByID</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">categories</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-33"><a name="L-33"></a> <span class="kd">var</span> <span class="nx">cat</span> <span class="o">=</span> <span class="kc">false</span><span class="p">;</span> </span><span id="L-34"><a name="L-34"></a> </span><span id="L-35"><a name="L-35"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">index</span> <span class="k">in</span> <span class="nx">categories</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-36"><a name="L-36"></a> <span class="kd">var</span> <span class="nx">category</span> <span class="o">=</span> <span class="nx">categories</span><span class="p">[</span><span class="nx">index</span><span class="p">];</span> </span><span id="L-37"><a name="L-37"></a> </span><span id="L-38"><a name="L-38"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">category</span><span class="p">.</span><span class="nx">id</span> <span class="o">==</span> <span class="nx">id</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-39"><a name="L-39"></a> <span class="nx">cat</span> <span class="o">=</span> <span class="nx">category</span><span class="p">;</span> </span><span id="L-40"><a name="L-40"></a> <span class="p">}</span> <span class="k">else</span> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">category</span><span class="p">.</span><span class="nx">categories</span> <span class="o">!=</span> <span class="s1">&#39;undefined&#39;</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-41"><a name="L-41"></a> <span class="nx">cat</span> <span class="o">=</span> <span class="nx">$scope</span><span class="p">.</span><span class="nx">getCategoryByID</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">category</span><span class="p">.</span><span class="nx">categories</span><span class="p">);</span> </span><span id="L-42"><a name="L-42"></a> <span class="p">}</span> </span><span id="L-43"><a name="L-43"></a> </span><span id="L-44"><a name="L-44"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">cat</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-45"><a name="L-45"></a> <span class="k">break</span><span class="p">;</span> </span><span id="L-46"><a name="L-46"></a> <span class="p">}</span> </span><span id="L-47"><a name="L-47"></a> <span class="p">}</span> </span><span id="L-48"><a name="L-48"></a> </span><span id="L-49"><a name="L-49"></a> <span class="k">return</span> <span class="nx">cat</span><span class="p">;</span> </span><span id="L-50"><a name="L-50"></a> <span class="p">};</span> </span><span id="L-51"><a name="L-51"></a> </span><span id="L-52"><a name="L-52"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">getCategory</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">name</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-53"><a name="L-53"></a> <span class="kd">var</span> <span class="nx">category</span> <span class="o">=</span> <span class="nx">$scope</span><span class="p">.</span><span class="nx">getCategoryByID</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">$scope</span><span class="p">[</span><span class="nx">name</span><span class="p">]);</span> </span><span id="L-54"><a name="L-54"></a> <span class="k">return</span> <span class="nx">category</span><span class="p">;</span> </span><span id="L-55"><a name="L-55"></a> <span class="p">};</span> </span><span id="L-56"><a name="L-56"></a> </span><span id="L-57"><a name="L-57"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">checkCategory</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">name</span><span class="p">,</span> <span class="nx">params</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-58"><a name="L-58"></a> <span class="kd">var</span> <span class="nx">category</span> <span class="o">=</span> <span class="nx">$scope</span><span class="p">.</span><span class="nx">getCategory</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">name</span><span class="p">);</span> </span><span id="L-59"><a name="L-59"></a> </span><span id="L-60"><a name="L-60"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">category</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-61"><a name="L-61"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">p</span> <span class="k">in</span> <span class="nx">params</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-62"><a name="L-62"></a> <span class="nx">category</span><span class="p">[</span><span class="nx">p</span><span class="p">]</span> <span class="o">=</span> <span class="nx">params</span><span class="p">[</span><span class="nx">p</span><span class="p">];</span> </span><span id="L-63"><a name="L-63"></a> <span class="p">}</span> </span><span id="L-64"><a name="L-64"></a> </span><span id="L-65"><a name="L-65"></a> <span class="kd">var</span> <span class="nx">categories</span> <span class="o">=</span> <span class="nx">category</span><span class="p">.</span><span class="nx">categories</span><span class="p">;</span> </span><span id="L-66"><a name="L-66"></a> </span><span id="L-67"><a name="L-67"></a> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">categories</span> <span class="o">==</span> <span class="s1">&#39;object&#39;</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-68"><a name="L-68"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">index</span> <span class="k">in</span> <span class="nx">categories</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-69"><a name="L-69"></a> <span class="kd">var</span> <span class="nx">cat</span> <span class="o">=</span> <span class="nx">categories</span><span class="p">[</span><span class="nx">index</span><span class="p">];</span> </span><span id="L-70"><a name="L-70"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">checkCategory</span><span class="p">(</span><span class="nx">cat</span><span class="p">.</span><span class="nx">id</span><span class="p">,</span> <span class="nx">name</span><span class="p">,</span> <span class="nx">params</span><span class="p">);</span> </span><span id="L-71"><a name="L-71"></a> <span class="p">}</span> </span><span id="L-72"><a name="L-72"></a> <span class="p">}</span> </span><span id="L-73"><a name="L-73"></a> <span class="p">}</span> </span><span id="L-74"><a name="L-74"></a> <span class="p">};</span> </span><span id="L-75"><a name="L-75"></a> </span><span id="L-76"><a name="L-76"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">checkItem</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">value</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-77"><a name="L-77"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">value</span> <span class="o">===</span> <span class="kc">null</span><span class="p">)</span> <span class="nx">value</span> <span class="o">=</span> <span class="kc">true</span><span class="p">;</span> </span><span id="L-78"><a name="L-78"></a> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">value</span> <span class="o">!=</span> <span class="s1">&#39;boolean&#39;</span><span class="p">)</span> <span class="k">return</span><span class="p">;</span> </span><span id="L-79"><a name="L-79"></a> </span><span id="L-80"><a name="L-80"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">checkCategory</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="s1">&#39;positions&#39;</span><span class="p">,</span> <span class="p">{</span> <span class="s1">&#39;checked&#39;</span> <span class="o">:</span> <span class="nx">value</span> <span class="p">});</span> </span><span id="L-81"><a name="L-81"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">checkCategory</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="s1">&#39;departments&#39;</span><span class="p">,</span> <span class="p">{</span> <span class="s1">&#39;checked&#39;</span> <span class="o">:</span> <span class="nx">value</span> <span class="p">});</span> </span><span id="L-82"><a name="L-82"></a> <span class="p">};</span> </span><span id="L-83"><a name="L-83"></a> </span><span id="L-84"><a name="L-84"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showModal</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-85"><a name="L-85"></a> <span class="nx">$</span><span class="p">(</span><span class="s1">&#39;#modal&lt;?=$prop_id?&gt;&#39;</span><span class="p">).</span><span class="nx">modal</span><span class="p">().</span><span class="nx">modal</span><span class="p">(</span><span class="s1">&#39;show&#39;</span><span class="p">);</span> </span><span id="L-86"><a name="L-86"></a> <span class="k">return</span> <span class="kc">false</span><span class="p">;</span> </span><span id="L-87"><a name="L-87"></a> <span class="p">}</span> </span><span id="L-88"><a name="L-88"></a> </span><span id="L-89"><a name="L-89"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showAll</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">jqxItems</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-90"><a name="L-90"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">index</span> <span class="k">in</span> <span class="nx">jqxItems</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-91"><a name="L-91"></a> <span class="kd">var</span> <span class="nx">item</span> <span class="o">=</span> <span class="nx">jqxItems</span><span class="p">[</span><span class="nx">index</span><span class="p">];</span> </span><span id="L-92"><a name="L-92"></a> <span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">element</span><span class="p">;</span> </span><span id="L-93"><a name="L-93"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">show</span><span class="p">();</span> </span><span id="L-94"><a name="L-94"></a> <span class="p">}</span> </span><span id="L-95"><a name="L-95"></a> <span class="p">}</span> </span><span id="L-96"><a name="L-96"></a> </span><span id="L-97"><a name="L-97"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">hideAll</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">jqxItems</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-98"><a name="L-98"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">index</span> <span class="k">in</span> <span class="nx">jqxItems</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-99"><a name="L-99"></a> <span class="kd">var</span> <span class="nx">item</span> <span class="o">=</span> <span class="nx">jqxItems</span><span class="p">[</span><span class="nx">index</span><span class="p">];</span> </span><span id="L-100"><a name="L-100"></a> <span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">element</span><span class="p">;</span> </span><span id="L-101"><a name="L-101"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">hide</span><span class="p">();</span> </span><span id="L-102"><a name="L-102"></a> <span class="p">}</span> </span><span id="L-103"><a name="L-103"></a> <span class="p">}</span> </span><span id="L-104"><a name="L-104"></a> </span><span id="L-105"><a name="L-105"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showItem</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">item</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-106"><a name="L-106"></a> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">item</span> <span class="o">==</span> <span class="s1">&#39;undefined&#39;</span> <span class="o">||</span> <span class="nx">item</span> <span class="o">==</span> <span class="kc">null</span><span class="p">)</span> <span class="k">return</span><span class="p">;</span> </span><span id="L-107"><a name="L-107"></a> </span><span id="L-108"><a name="L-108"></a> <span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">element</span><span class="p">;</span> </span><span id="L-109"><a name="L-109"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">show</span><span class="p">();</span> </span><span id="L-110"><a name="L-110"></a> </span><span id="L-111"><a name="L-111"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">item</span><span class="p">.</span><span class="nx">level</span> <span class="o">&gt;</span> <span class="mi">0</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-112"><a name="L-112"></a> <span class="kd">var</span> <span class="nx">parentElement</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">parentElement</span><span class="p">;</span> </span><span id="L-113"><a name="L-113"></a> <span class="kd">var</span> <span class="nx">parent</span> <span class="o">=</span> <span class="nx">jqx</span><span class="p">.</span><span class="nx">jqxTree</span><span class="p">(</span><span class="s1">&#39;getItem&#39;</span><span class="p">,</span> <span class="nx">parentElement</span><span class="p">);</span> </span><span id="L-114"><a name="L-114"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showItem</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">parent</span><span class="p">);</span> </span><span id="L-115"><a name="L-115"></a> <span class="p">}</span> </span><span id="L-116"><a name="L-116"></a> <span class="p">}</span> </span><span id="L-117"><a name="L-117"></a> </span><span id="L-118"><a name="L-118"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">hideItem</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">item</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-119"><a name="L-119"></a> <span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">element</span><span class="p">;</span> </span><span id="L-120"><a name="L-120"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">hide</span><span class="p">();</span> </span><span id="L-121"><a name="L-121"></a> <span class="p">}</span> </span><span id="L-122"><a name="L-122"></a> </span><span id="L-123"><a name="L-123"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">filterItems</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">jqxItems</span><span class="p">,</span> <span class="nx">pattern</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-124"><a name="L-124"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">hideAll</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">jqxItems</span><span class="p">);</span> </span><span id="L-125"><a name="L-125"></a> </span><span id="L-126"><a name="L-126"></a> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">index</span> <span class="k">in</span> <span class="nx">jqxItems</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-127"><a name="L-127"></a> <span class="kd">var</span> <span class="nx">item</span> <span class="o">=</span> <span class="nx">jqxItems</span><span class="p">[</span><span class="nx">index</span><span class="p">];</span> </span><span id="L-128"><a name="L-128"></a> </span><span id="L-129"><a name="L-129"></a> <span class="kd">var</span> <span class="nx">text</span> <span class="o">=</span> <span class="nx">item</span><span class="p">.</span><span class="nx">label</span><span class="p">;</span> </span><span id="L-130"><a name="L-130"></a> <span class="kd">var</span> <span class="nx">result</span> <span class="o">=</span> <span class="nx">text</span><span class="p">.</span><span class="nx">search</span><span class="p">(</span><span class="nx">pattern</span><span class="p">);</span> </span><span id="L-131"><a name="L-131"></a> </span><span id="L-132"><a name="L-132"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">result</span> <span class="o">&gt;=</span> <span class="mi">0</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-133"><a name="L-133"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showItem</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">item</span><span class="p">);</span> </span><span id="L-134"><a name="L-134"></a> <span class="p">}</span> </span><span id="L-135"><a name="L-135"></a> <span class="p">}</span> </span><span id="L-136"><a name="L-136"></a> <span class="p">}</span> </span><span id="L-137"><a name="L-137"></a> </span><span id="L-138"><a name="L-138"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">search</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">selector</span><span class="p">,</span> <span class="nx">search</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-139"><a name="L-139"></a> <span class="kd">var</span> <span class="nx">jqx</span> <span class="o">=</span> <span class="nx">$</span><span class="p">(</span><span class="nx">selector</span><span class="p">);</span> </span><span id="L-140"><a name="L-140"></a> <span class="kd">var</span> <span class="nx">items</span> <span class="o">=</span> <span class="nx">jqx</span><span class="p">.</span><span class="nx">jqxTree</span><span class="p">(</span><span class="s1">&#39;getItems&#39;</span><span class="p">);</span> </span><span id="L-141"><a name="L-141"></a> <span class="kd">var</span> <span class="nx">pattern</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">RegExp</span><span class="p">(</span><span class="nx">search</span><span class="p">,</span> <span class="s2">&quot;i&quot;</span><span class="p">);</span> </span><span id="L-142"><a name="L-142"></a> </span><span id="L-143"><a name="L-143"></a> <span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">search</span> <span class="o">==</span> <span class="s1">&#39;undefined&#39;</span> <span class="o">||</span> <span class="nx">search</span> <span class="o">==</span> <span class="s1">&#39;&#39;</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-144"><a name="L-144"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">showAll</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">items</span><span class="p">);</span> </span><span id="L-145"><a name="L-145"></a> <span class="k">return</span><span class="p">;</span> </span><span id="L-146"><a name="L-146"></a> <span class="p">}</span> </span><span id="L-147"><a name="L-147"></a> </span><span id="L-148"><a name="L-148"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">filterItems</span><span class="p">(</span><span class="nx">jqx</span><span class="p">,</span> <span class="nx">items</span><span class="p">,</span> <span class="nx">pattern</span><span class="p">);</span> </span><span id="L-149"><a name="L-149"></a> <span class="p">}</span> </span><span id="L-150"><a name="L-150"></a> </span><span id="L-151"><a name="L-151"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">initPopup</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-152"><a name="L-152"></a> <span class="nx">$</span><span class="p">(</span><span class="s1">&#39;.ui .label&#39;</span><span class="p">).</span><span class="nx">each</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-153"><a name="L-153"></a> <span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">$</span><span class="p">(</span><span class="k">this</span><span class="p">).</span><span class="nx">find</span><span class="p">(</span><span class="s1">&#39;.popup&#39;</span><span class="p">);</span> </span><span id="L-154"><a name="L-154"></a> </span><span id="L-155"><a name="L-155"></a> <span class="k">if</span> <span class="p">(</span><span class="nx">elem</span><span class="p">.</span><span class="nx">length</span> <span class="o">&gt;</span> <span class="mi">0</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-156"><a name="L-156"></a> <span class="nx">elem</span> <span class="o">=</span> <span class="nx">elem</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span> </span><span id="L-157"><a name="L-157"></a> <span class="nx">$</span><span class="p">(</span><span class="k">this</span><span class="p">).</span><span class="nx">popup</span><span class="p">({</span> </span><span id="L-158"><a name="L-158"></a> <span class="nx">popup</span><span class="o">:</span> <span class="nx">elem</span> </span><span id="L-159"><a name="L-159"></a> <span class="p">});</span> </span><span id="L-160"><a name="L-160"></a> <span class="p">}</span> </span><span id="L-161"><a name="L-161"></a> <span class="p">});</span> </span><span id="L-162"><a name="L-162"></a> <span class="p">}</span> </span><span id="L-163"><a name="L-163"></a> </span><span id="L-164"><a name="L-164"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">$watch</span><span class="p">(</span><span class="s1">&#39;searchPosition&#39;</span><span class="p">,</span> <span class="kd">function</span><span class="p">(</span><span class="nx">newVal</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-165"><a name="L-165"></a> <span class="kd">var</span> <span class="nx">selector</span> <span class="o">=</span> <span class="s1">&#39;#jqxTree-position&lt;?=$prop_id?&gt;&#39;</span><span class="p">;</span> </span><span id="L-166"><a name="L-166"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">search</span><span class="p">(</span><span class="nx">selector</span><span class="p">,</span> <span class="nx">newVal</span><span class="p">);</span> </span><span id="L-167"><a name="L-167"></a> <span class="p">});</span> </span><span id="L-168"><a name="L-168"></a> </span><span id="L-169"><a name="L-169"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">$watch</span><span class="p">(</span><span class="s1">&#39;searchDepartment&#39;</span><span class="p">,</span> <span class="kd">function</span><span class="p">(</span><span class="nx">newVal</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-170"><a name="L-170"></a> <span class="kd">var</span> <span class="nx">selector</span> <span class="o">=</span> <span class="s1">&#39;#jqxTree-department&lt;?=$prop_id?&gt;&#39;</span><span class="p">;</span> </span><span id="L-171"><a name="L-171"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">search</span><span class="p">(</span><span class="nx">selector</span><span class="p">,</span> <span class="nx">newVal</span><span class="p">);</span> </span><span id="L-172"><a name="L-172"></a> <span class="p">});</span> </span><span id="L-173"><a name="L-173"></a> </span><span id="L-174"><a name="L-174"></a> <span class="nx">angular</span><span class="p">.</span><span class="nx">element</span><span class="p">(</span><span class="nb">document</span><span class="p">).</span><span class="nx">ready</span><span class="p">(</span><span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> </span><span id="L-175"><a name="L-175"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">initPopup</span><span class="p">();</span> </span><span id="L-176"><a name="L-176"></a> <span class="nx">$</span><span class="p">(</span><span class="s1">&#39;.edit-button&#39;</span><span class="p">).</span><span class="nx">click</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-177"><a name="L-177"></a> <span class="k">return</span> <span class="kc">false</span><span class="p">;</span> </span><span id="L-178"><a name="L-178"></a> <span class="p">});</span> </span><span id="L-179"><a name="L-179"></a> <span class="p">});</span> </span><span id="L-180"><a name="L-180"></a> <span class="p">}]);</span> </span><span id="L-181"><a name="L-181"></a> </span><span id="L-182"><a name="L-182"></a> <span class="nx">app</span><span class="p">.</span><span class="nx">directive</span><span class="p">(</span><span class="s1">&#39;semanticTab&lt;?=$prop_id?&gt;&#39;</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-183"><a name="L-183"></a> <span class="k">return</span> <span class="kd">function</span><span class="p">(</span><span class="nx">$scope</span><span class="p">,</span> <span class="nx">elem</span><span class="p">,</span> <span class="nx">attrs</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-184"><a name="L-184"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">tab</span><span class="p">();</span> </span><span id="L-185"><a name="L-185"></a> <span class="p">};</span> </span><span id="L-186"><a name="L-186"></a> <span class="p">});</span> </span><span id="L-187"><a name="L-187"></a> </span><span id="L-188"><a name="L-188"></a> <span class="nx">app</span><span class="p">.</span><span class="nx">directive</span><span class="p">(</span><span class="s1">&#39;jqxTree&lt;?=$prop_id?&gt;&#39;</span><span class="p">,</span> <span class="p">[</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-189"><a name="L-189"></a> <span class="k">return</span> <span class="p">{</span> </span><span id="L-190"><a name="L-190"></a> <span class="nx">restrict</span><span class="o">:</span> <span class="s1">&#39;A&#39;</span><span class="p">,</span> </span><span id="L-191"><a name="L-191"></a> <span class="nx">scope</span><span class="o">:</span> <span class="p">{</span> </span><span id="L-192"><a name="L-192"></a> <span class="s1">&#39;model&#39;</span><span class="o">:</span> <span class="s1">&#39;=&#39;</span> </span><span id="L-193"><a name="L-193"></a> <span class="p">},</span> </span><span id="L-194"><a name="L-194"></a> <span class="nx">link</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">$scope</span><span class="p">,</span> <span class="nx">elem</span><span class="p">,</span> <span class="nx">attrs</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-195"><a name="L-195"></a> <span class="nx">$</span><span class="p">(</span><span class="nb">document</span><span class="p">).</span><span class="nx">ready</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-196"><a name="L-196"></a> <span class="nx">$</span><span class="p">(</span><span class="nx">elem</span><span class="p">).</span><span class="nx">jqxTree</span><span class="p">({</span> </span><span id="L-197"><a name="L-197"></a> <span class="nx">hasThreeStates</span><span class="o">:</span> <span class="kc">true</span><span class="p">,</span> </span><span id="L-198"><a name="L-198"></a> <span class="nx">checkboxes</span><span class="o">:</span> <span class="kc">true</span><span class="p">,</span> </span><span id="L-199"><a name="L-199"></a> <span class="nx">height</span><span class="o">:</span> <span class="s1">&#39;300px&#39;</span> </span><span id="L-200"><a name="L-200"></a> <span class="p">})</span> </span><span id="L-201"><a name="L-201"></a> <span class="p">.</span><span class="nx">on</span><span class="p">(</span><span class="s1">&#39;checkChange&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">event</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-202"><a name="L-202"></a> <span class="kd">var</span> <span class="nx">args</span> <span class="o">=</span> <span class="nx">event</span><span class="p">.</span><span class="nx">args</span><span class="p">;</span> </span><span id="L-203"><a name="L-203"></a> <span class="kd">var</span> <span class="nx">element</span> <span class="o">=</span> <span class="nx">args</span><span class="p">.</span><span class="nx">element</span><span class="p">;</span> </span><span id="L-204"><a name="L-204"></a> <span class="kd">var</span> <span class="nx">checked</span> <span class="o">=</span> <span class="nx">args</span><span class="p">.</span><span class="nx">checked</span><span class="p">;</span> </span><span id="L-205"><a name="L-205"></a> <span class="kd">var</span> <span class="nx">id</span> <span class="o">=</span> <span class="nx">$</span><span class="p">(</span><span class="nx">element</span><span class="p">).</span><span class="nx">attr</span><span class="p">(</span><span class="s1">&#39;item-id&#39;</span><span class="p">);</span> </span><span id="L-206"><a name="L-206"></a> </span><span id="L-207"><a name="L-207"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">$apply</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-208"><a name="L-208"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">$parent</span><span class="p">.</span><span class="nx">checkItem</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">checked</span><span class="p">);</span> </span><span id="L-209"><a name="L-209"></a> </span><span id="L-210"><a name="L-210"></a> <span class="c1">// delay for init popup</span> </span><span id="L-211"><a name="L-211"></a> <span class="nx">setTimeout</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> </span><span id="L-212"><a name="L-212"></a> <span class="nx">$scope</span><span class="p">.</span><span class="nx">$parent</span><span class="p">.</span><span class="nx">initPopup</span><span class="p">();</span> </span><span id="L-213"><a name="L-213"></a> <span class="p">},</span> <span class="mi">500</span><span class="p">);</span> </span><span id="L-214"><a name="L-214"></a> <span class="p">});</span> </span><span id="L-215"><a name="L-215"></a> <span class="p">})</span> </span><span id="L-216"><a name="L-216"></a> <span class="p">.</span><span class="nx">css</span><span class="p">(</span><span class="s1">&#39;visibility&#39;</span><span class="p">,</span> <span class="s1">&#39;visible&#39;</span><span class="p">);</span> </span><span id="L-217"><a name="L-217"></a> <span class="p">});</span> </span><span id="L-218"><a name="L-218"></a> <span class="p">}</span> </span><span id="L-219"><a name="L-219"></a> <span class="p">}</span> </span><span id="L-220"><a name="L-220"></a> <span class="p">}]);</span> </span><span id="L-221"><a name="L-221"></a><span class="o">&lt;</span><span class="err">/script&gt;</span> </span></pre></div> </td></tr></table>
custom
--- 
+++ 
@@ -0,0 +1,221 @@
+<script type="text/javascript">
+    app.controller('myController<?=$prop_id?>', ['$scope', function($scope) {
+
+    	$scope.positions = <?=CUtil::PhpToJSObject($arPositions)?>;
+		$scope.departments = <?=CUtil::PhpToJSObject($arDepartments)?>;
+
+    	$scope.isChecked = function(value) {
+    		var unchecked =  (typeof value == 'undefined') || (typeof value == 'boolean' && value === false);
+    		return !unchecked;
+    	};
+
+    	$scope.hasChecked = function(item) {
+    		var checked = item.checked;
+    		if ($scope.isChecked(checked)) return true;
+
+    		var cats = item.categories;
+    		
+    		for (var c in cats) {
+    			var g = cats[c];
+    			var checked = $scope.isChecked(g.checked);
+
+    			if (checked) return true;
+
+    			if (typeof g.categories == 'object') {
+    				return $scope.hasChecked(g);
+    			}
+    		}
+
+    		return false;
+    	}
+
+    	$scope.getCategoryByID = function(id, categories) {
+    		var cat = false;
+
+    		for (var index in categories) {
+    			var category = categories[index];
+    			
+    			if (category.id == id) {
+    				cat = category;
+    			} else if (typeof category.categories != 'undefined') {
+    				cat = $scope.getCategoryByID(id, category.categories);
+    			}
+
+    			if (cat) {
+    				break;
+    			}
+			}
+
+			return cat;
+    	};
+
+    	$scope.getCategory = function(id, name) {
+    		var category = $scope.getCategoryByID(id, $scope[name]);
+    		return category;
+    	};
+
+    	$scope.checkCategory = function(id, name, params) {
+			var category = $scope.getCategory(id, name);
+
+			if (category) {
+				for (var p in params) {
+					category[p] = params[p];
+				}
+
+				var categories = category.categories;
+
+				if (typeof categories == 'object') {
+					for (var index in categories) {
+						var cat = categories[index];
+						$scope.checkCategory(cat.id, name, params);
+					}
+				}
+			}
+    	};
+
+    	$scope.checkItem = function(id, value) {
+    		if (value === null) value = true;
+    		if (typeof value != 'boolean') return;
+
+    		$scope.checkCategory(id, 'positions', { 'checked' : value });
+    		$scope.checkCategory(id, 'departments', { 'checked' : value });
+    	};
+
+    	$scope.showModal = function() {
+    		$('#modal<?=$prop_id?>').modal().modal('show');
+            return false;
+    	}
+
+    	$scope.showAll = function(jqx, jqxItems) {
+    		for (var index in jqxItems) {
+    			var item = jqxItems[index];
+    			var elem = item.element;
+    			$(elem).show();
+    		}
+    	}
+
+    	$scope.hideAll = function(jqx, jqxItems) {
+    		for (var index in jqxItems) {
+    			var item = jqxItems[index];
+    			var elem = item.element;
+    			$(elem).hide();
+    		}
+    	}
+
+    	$scope.showItem = function(jqx, item) {
+			if (typeof item == 'undefined' || item == null) return;
+
+			var elem = item.element;
+			$(elem).show();
+
+			if (item.level > 0) {
+				var parentElement = item.parentElement;
+				var parent = jqx.jqxTree('getItem', parentElement);
+				$scope.showItem(jqx, parent);
+			}
+    	}
+
+    	$scope.hideItem = function(jqx, item) {
+			var elem = item.element;
+			$(elem).hide();
+    	}
+
+    	$scope.filterItems = function(jqx, jqxItems, pattern) {
+    		$scope.hideAll(jqx, jqxItems);
+
+    		for (var index in jqxItems) {
+    			var item = jqxItems[index];
+    			
+    			var text = item.label;
+    			var result = text.search(pattern);
+
+    			if (result >= 0) {
+    				$scope.showItem(jqx, item);
+    			}
+    		}        		
+    	}
+
+    	$scope.search = function(selector, search) {
+    		var jqx = $(selector);
+    		var items = jqx.jqxTree('getItems');
+    		var pattern = new RegExp(search, "i");
+
+    		if (typeof search == 'undefined' || search == '') {
+    			$scope.showAll(jqx, items);
+    			return;
+    		}
+
+    		$scope.filterItems(jqx, items, pattern);
+    	}
+
+    	$scope.initPopup = function() {
+    		$('.ui .label').each(function() {
+        		var elem = $(this).find('.popup');
+        		
+        		if (elem.length > 0) {
+        			elem = elem[0];
+            		$(this).popup({
+            			popup: elem
+            		});
+        		}
+        	});
+    	}
+
+    	$scope.$watch('searchPosition', function(newVal) {
+    		var selector = '#jqxTree-position<?=$prop_id?>';
+    		$scope.search(selector, newVal);
+    	});
+
+    	$scope.$watch('searchDepartment', function(newVal) {
+    		var selector = '#jqxTree-department<?=$prop_id?>';
+    		$scope.search(selector, newVal);
+    	});
+
+    	angular.element(document).ready(function () {
+	        $scope.initPopup();
+            $('.edit-button').click(function() {
+                return false;
+            });
+	    });
+    }]);
+
+	app.directive('semanticTab<?=$prop_id?>', function() {
+		return function($scope, elem, attrs) {
+			$(elem).tab();
+		};
+	});
+
+	app.directive('jqxTree<?=$prop_id?>', [function() {
+		return {
+			restrict: 'A',
+			scope: {
+		      'model': '='
+		    },
+		    link: function($scope, elem, attrs) {
+		    	$(document).ready(function() {
+			    	$(elem).jqxTree({
+			        	hasThreeStates: true,
+			        	checkboxes: true,
+			        	height: '300px'
+			        })
+			        .on('checkChange', function (event) {
+					    var args = event.args;
+					    var element = args.element;
+					    var checked = args.checked;
+					    var id = $(element).attr('item-id');
+					    
+					    $scope.$apply(function() {
+				            $scope.$parent.checkItem(id, checked);
+				            
+				            // delay for init popup
+				            setTimeout(function() {
+				            	$scope.$parent.initPopup();
+				            }, 500);
+				        });
+					})
+					.css('visibility', 'visible');
+		    	});
+		    }
+		}
+	}]);
+</script>
  • ribab
  • 3 years, 5 months ago