1: <?php
2: /**
3: * LICENSE (BSD)
4: *
5: * Copyright (c) 2013, Gerd Christian Kunze
6: * All rights reserved.
7: *
8: * Redistribution and use in source and binary forms, with or without
9: * modification, are permitted provided that the following conditions are
10: * met:
11: *
12: * * Redistributions of source code must retain the above copyright
13: * notice, this list of conditions and the following disclaimer.
14: *
15: * * Redistributions in binary form must reproduce the above copyright
16: * notice, this list of conditions and the following disclaimer in the
17: * documentation and/or other materials provided with the distribution.
18: *
19: * * Neither the name of Gerd Christian Kunze nor the names of the
20: * contributors may be used to endorse or promote products derived from
21: * this software without specific prior written permission.
22: *
23: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
24: * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
25: * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
27: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34: *
35: * Style
36: * 18.02.2013 13:55
37: */
38: namespace MOC\Module\Office\Document\Excel\Cell\Style\Border\Top;
39: use MOC\Api;
40: use MOC\Generic\Device\Module;
41:
42: /**
43: *
44: */
45: class Style implements Module {
46: /**
47: * Get Changelog
48: *
49: * @static
50: * @return \MOC\Core\Changelog
51: */
52: public static function InterfaceChangelog() {
53: return Api::Core()->Changelog()->Create( __CLASS__ );
54: }
55:
56: /**
57: * Get Dependencies
58: *
59: * @static
60: * @return \MOC\Core\Depending
61: */
62: public static function InterfaceDepending() {
63: return Api::Core()->Depending();
64: }
65:
66: /**
67: * Get Singleton/Instance
68: *
69: * @static
70: * @return Style
71: */
72: public static function InterfaceInstance() {
73: return new Style();
74: }
75:
76: /**
77: * @return \MOC\Module\Office\Document\Excel
78: */
79: public function None() {
80: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_NONE );
81: return Api::Module()->Office()->Document()->Excel();
82: }
83:
84: /**
85: * @return \MOC\Module\Office\Document\Excel
86: */
87: public function DashDot() {
88: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_DASHDOT );
89: return Api::Module()->Office()->Document()->Excel();
90: }
91:
92: /**
93: * @return \MOC\Module\Office\Document\Excel
94: */
95: public function DashDotDot() {
96: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_DASHDOTDOT );
97: return Api::Module()->Office()->Document()->Excel();
98: }
99:
100: /**
101: * @return \MOC\Module\Office\Document\Excel
102: */
103: public function Dashed() {
104: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_DASHED );
105: return Api::Module()->Office()->Document()->Excel();
106: }
107:
108: /**
109: * @return \MOC\Module\Office\Document\Excel
110: */
111: public function Dotted() {
112: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_DOTTED );
113: return Api::Module()->Office()->Document()->Excel();
114: }
115:
116: /**
117: * @return \MOC\Module\Office\Document\Excel
118: */
119: public function Double() {
120: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_DOUBLE );
121: return Api::Module()->Office()->Document()->Excel();
122: }
123:
124:
125: /**
126: * @return \MOC\Module\Office\Document\Excel
127: */
128: public function Hair() {
129: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_HAIR );
130: return Api::Module()->Office()->Document()->Excel();
131: }
132:
133:
134: /**
135: * @return \MOC\Module\Office\Document\Excel
136: */
137: public function Medium() {
138: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_MEDIUM );
139: return Api::Module()->Office()->Document()->Excel();
140: }
141:
142:
143: /**
144: * @return \MOC\Module\Office\Document\Excel
145: */
146: public function MediumDashDot() {
147: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_MEDIUMDASHDOT );
148: return Api::Module()->Office()->Document()->Excel();
149: }
150:
151:
152: /**
153: * @return \MOC\Module\Office\Document\Excel
154: */
155: public function MediumDashDotDot() {
156: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_MEDIUMDASHDOTDOT );
157: return Api::Module()->Office()->Document()->Excel();
158: }
159:
160:
161: /**
162: * @return \MOC\Module\Office\Document\Excel
163: */
164: public function MediumDashed() {
165: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_MEDIUMDASHED );
166: return Api::Module()->Office()->Document()->Excel();
167: }
168:
169:
170: /**
171: * @return \MOC\Module\Office\Document\Excel
172: */
173: public function SlantDashDot() {
174: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_SLANTDASHDOT );
175: return Api::Module()->Office()->Document()->Excel();
176: }
177:
178:
179: /**
180: * @return \MOC\Module\Office\Document\Excel
181: */
182: public function Thick() {
183: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_THICK );
184: return Api::Module()->Office()->Document()->Excel();
185: }
186:
187:
188: /**
189: * @return \MOC\Module\Office\Document\Excel
190: */
191: public function Thin() {
192: $this->getBorder()->setBorderStyle( \PHPExcel_Style_Border::BORDER_THIN );
193: return Api::Module()->Office()->Document()->Excel();
194: }
195:
196: /**
197: * @return \PHPExcel_Style_Border
198: */
199: private function getBorder() {
200: return Api::Extension()->Excel()->Current()
201: ->getActiveSheet()
202: ->getStyle(
203: Api::Module()->Office()->Document()->Excel()
204: ->Cell()->Select()->Current()
205: )
206: ->getBorders()
207: ->getTop();
208: }
209: }
210: