From 7ae9123eca90c8a684f9515a0e9a4d9cb3ac7527 Mon Sep 17 00:00:00 2001 From: Nurmuhammet Allanov Date: Sat, 9 Nov 2024 23:16:09 +0500 Subject: [PATCH] Invoice and php excell working --- .DS_Store | Bin 6148 -> 8196 bytes app/Modules/.DS_Store | Bin 6148 -> 6148 bytes app/Modules/Invoice/.DS_Store | Bin 0 -> 6148 bytes .../Invoice/Controllers/InvoiceController.php | 49 +++ ...024_11_09_185929_create_invoices_table.php | 24 ++ app/Modules/Invoice/InvoiceModule.php | 48 +++ app/Modules/Invoice/Models/Invoice.php | 11 + .../Repositories/InvoiceRepository.php | 10 + app/Modules/Invoice/Resources/.DS_Store | Bin 0 -> 6148 bytes .../Invoice/Resources/Docs/invoice.xls | Bin 0 -> 34816 bytes app/Modules/PHPExcell/.DS_Store | Bin 0 -> 6148 bytes app/Modules/PHPExcell/PHPExcellModule.php | 48 +++ composer.json | 1 + composer.lock | 290 +++++++++++++++++- public/write.xls | Bin 0 -> 15872 bytes routes/web.php | 82 ++++- 16 files changed, 561 insertions(+), 2 deletions(-) create mode 100644 app/Modules/Invoice/.DS_Store create mode 100644 app/Modules/Invoice/Controllers/InvoiceController.php create mode 100644 app/Modules/Invoice/Database/Migrations/2024_11_09_185929_create_invoices_table.php create mode 100644 app/Modules/Invoice/InvoiceModule.php create mode 100644 app/Modules/Invoice/Models/Invoice.php create mode 100644 app/Modules/Invoice/Repositories/InvoiceRepository.php create mode 100644 app/Modules/Invoice/Resources/.DS_Store create mode 100755 app/Modules/Invoice/Resources/Docs/invoice.xls create mode 100644 app/Modules/PHPExcell/.DS_Store create mode 100644 app/Modules/PHPExcell/PHPExcellModule.php create mode 100644 public/write.xls diff --git a/.DS_Store b/.DS_Store index 1b58ec436f6164596ed3ddf9e11b1b4749ac30e7..a820ce67819c55fb547f669abcdbbf3ea0725883 100644 GIT binary patch delta 198 zcmZoMXmOBWU|?W$DortDU;r^WfEYvza8E20o2aMA$h9$GH}hr%jz7$c**Q2SHn1>q zP3B?gVz)3d)lo1u*gTiTk5Q71p@5;3A&DV}A(J6Fsl2!#DJMS(Xv+4<0<48x;?>ng zmL@t1rk0cEu}Cv^PTs{LFW3c?M$xwT4lC2y5a0$9t{{yY3%@f@=9lpV8NB!ku~2NHo}wrV0|Nsi1A_nqLncEqLuyiaaY0hfW<}=Z%)%fkb_P#| zJccrce2Da94W{GLXkul-MR_^-dFdd7HuEsCGjC?+;O79^05s)0^JIPzM-HF`Oh9Rd J%@HDNm;v$C8j1h_ delta 85 zcmZoMXfc=|#>B)qu~2NHo}wrd0|Nsi1A_nqLn=caLkWXFLlHyD#=_-{lMO^zHZ!xb mFmG)5!nB#4gP#MaX|o{5cjn3bB90tDZ6JLtn+VK_0FV>{E6N6&%@5JRa!fi@t_^XoxV;8gARsVU4(HUhjp38L85a#Gr%40 zv`XdCXt%aq5j*?UaYc*{wyPDfyR$bQJA8d(>+rO7A9Z8-Xy|149IDscL=IkuG zt$8=H+na>VkLt=s!|tEIC(X@Q`EvAKWbnht-rY}De(?HnB;#9LZL+g3Kb1^kfEXYK zeuV*hzwqL(%tn(C1H`~0F`(`TfvV88m>JYp2R6C{K+L0C3)-rdP&vY)YcVs3BPh(I zBAQfYOAKbx(JySAYcVru(t+9HgV~jttx%X=9p@K19GGj6T4I10m}X$fbW7^}Kl#4? zpH8A4F+dC~6ay^Z@EUd8l6_leHmBZNfqIRqM8#zWKU2`qPcg=-r?`x&1^q%9h_1!V SAbL>fkAS9u8e-s28TbHY^l>x* literal 0 HcmV?d00001 diff --git a/app/Modules/Invoice/Controllers/InvoiceController.php b/app/Modules/Invoice/Controllers/InvoiceController.php new file mode 100644 index 0000000..dbde2c2 --- /dev/null +++ b/app/Modules/Invoice/Controllers/InvoiceController.php @@ -0,0 +1,49 @@ +enabled; + } + + /** + * Disable module + */ + public function disable(): void + { + $this->enabled = false; + } + + /** + * Enable module + */ + public function enable(): void + { + $this->enabled = true; + } + + /** + * Check if module has a filament resource + */ + public function hasFilamentResource(): bool + { + return true; + } +} diff --git a/app/Modules/Invoice/Models/Invoice.php b/app/Modules/Invoice/Models/Invoice.php new file mode 100644 index 0000000..4741484 --- /dev/null +++ b/app/Modules/Invoice/Models/Invoice.php @@ -0,0 +1,11 @@ +S~Jl7#VW15!DL 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 + } + + /** + * Disable module + */ + public function disable(): void + { + $this->enabled = false; + } + + /** + * Enable module + */ + public function enable(): void + { + $this->enabled = true; + } + + /** + * Check if module has a filament resource + */ + public function hasFilamentResource(): bool + { + return true; + } +} diff --git a/composer.json b/composer.json index 68d08d4..45b34d7 100644 --- a/composer.json +++ b/composer.json @@ -9,6 +9,7 @@ "filament/filament": "^3.2", "laravel/framework": "^11.9", "laravel/tinker": "^2.9", + "phpoffice/phpspreadsheet": "^3.3", "phpoffice/phpword": "^1.3" }, "require-dev": { diff --git a/composer.lock b/composer.lock index 4de9c05..530437b 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "8a4d84668f344ea1cf8145eb52a30343", + "content-hash": "2c5e3e156b6775d0bb4507a50ddce50a", "packages": [ { "name": "anourvalar/eloquent-serialize", @@ -3133,6 +3133,190 @@ ], "time": "2024-10-15T19:35:06+00:00" }, + { + "name": "maennchen/zipstream-php", + "version": "3.1.1", + "source": { + "type": "git", + "url": "https://github.com/maennchen/ZipStream-PHP.git", + "reference": "6187e9cc4493da94b9b63eb2315821552015fca9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/maennchen/ZipStream-PHP/zipball/6187e9cc4493da94b9b63eb2315821552015fca9", + "reference": "6187e9cc4493da94b9b63eb2315821552015fca9", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "ext-zlib": "*", + "php-64bit": "^8.1" + }, + "require-dev": { + "ext-zip": "*", + "friendsofphp/php-cs-fixer": "^3.16", + "guzzlehttp/guzzle": "^7.5", + "mikey179/vfsstream": "^1.6", + "php-coveralls/php-coveralls": "^2.5", + "phpunit/phpunit": "^10.0", + "vimeo/psalm": "^5.0" + }, + "suggest": { + "guzzlehttp/psr7": "^2.4", + "psr/http-message": "^2.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "ZipStream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Paul Duncan", + "email": "pabs@pablotron.org" + }, + { + "name": "Jonatan Männchen", + "email": "jonatan@maennchen.ch" + }, + { + "name": "Jesse Donat", + "email": "donatj@gmail.com" + }, + { + "name": "András Kolesár", + "email": "kolesar@kolesar.hu" + } + ], + "description": "ZipStream is a library for dynamically streaming dynamic zip files from PHP without writing to the disk at all on the server.", + "keywords": [ + "stream", + "zip" + ], + "support": { + "issues": "https://github.com/maennchen/ZipStream-PHP/issues", + "source": "https://github.com/maennchen/ZipStream-PHP/tree/3.1.1" + }, + "funding": [ + { + "url": "https://github.com/maennchen", + "type": "github" + } + ], + "time": "2024-10-10T12:33:01+00:00" + }, + { + "name": "markbaker/complex", + "version": "3.0.2", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPComplex.git", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPComplex/zipball/95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "reference": "95c56caa1cf5c766ad6d65b6344b807c1e8405b9", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "type": "library", + "autoload": { + "psr-4": { + "Complex\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@lange.demon.co.uk" + } + ], + "description": "PHP Class for working with complex numbers", + "homepage": "https://github.com/MarkBaker/PHPComplex", + "keywords": [ + "complex", + "mathematics" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPComplex/issues", + "source": "https://github.com/MarkBaker/PHPComplex/tree/3.0.2" + }, + "time": "2022-12-06T16:21:08+00:00" + }, + { + "name": "markbaker/matrix", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/MarkBaker/PHPMatrix.git", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/MarkBaker/PHPMatrix/zipball/728434227fe21be27ff6d86621a1b13107a2562c", + "reference": "728434227fe21be27ff6d86621a1b13107a2562c", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-master", + "phpcompatibility/php-compatibility": "^9.3", + "phpdocumentor/phpdocumentor": "2.*", + "phploc/phploc": "^4.0", + "phpmd/phpmd": "2.*", + "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0", + "sebastian/phpcpd": "^4.0", + "squizlabs/php_codesniffer": "^3.7" + }, + "type": "library", + "autoload": { + "psr-4": { + "Matrix\\": "classes/src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Mark Baker", + "email": "mark@demon-angel.eu" + } + ], + "description": "PHP Class for working with matrices", + "homepage": "https://github.com/MarkBaker/PHPMatrix", + "keywords": [ + "mathematics", + "matrix", + "vector" + ], + "support": { + "issues": "https://github.com/MarkBaker/PHPMatrix/issues", + "source": "https://github.com/MarkBaker/PHPMatrix/tree/3.0.1" + }, + "time": "2022-12-02T22:17:43+00:00" + }, { "name": "masterminds/html5", "version": "2.9.0", @@ -3845,6 +4029,110 @@ }, "time": "2024-08-12T07:30:45+00:00" }, + { + "name": "phpoffice/phpspreadsheet", + "version": "3.3.0", + "source": { + "type": "git", + "url": "https://github.com/PHPOffice/PhpSpreadsheet.git", + "reference": "87ddd21eb0b6b7ad20a11d314348ef307475f547" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPOffice/PhpSpreadsheet/zipball/87ddd21eb0b6b7ad20a11d314348ef307475f547", + "reference": "87ddd21eb0b6b7ad20a11d314348ef307475f547", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-dom": "*", + "ext-fileinfo": "*", + "ext-gd": "*", + "ext-iconv": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-simplexml": "*", + "ext-xml": "*", + "ext-xmlreader": "*", + "ext-xmlwriter": "*", + "ext-zip": "*", + "ext-zlib": "*", + "maennchen/zipstream-php": "^2.1 || ^3.0", + "markbaker/complex": "^3.0", + "markbaker/matrix": "^3.0", + "php": "^8.1", + "psr/http-client": "^1.0", + "psr/http-factory": "^1.0", + "psr/simple-cache": "^1.0 || ^2.0 || ^3.0" + }, + "require-dev": { + "dealerdirect/phpcodesniffer-composer-installer": "dev-main", + "dompdf/dompdf": "^2.0 || ^3.0", + "friendsofphp/php-cs-fixer": "^3.2", + "mitoteam/jpgraph": "^10.3", + "mpdf/mpdf": "^8.1.1", + "phpcompatibility/php-compatibility": "^9.3", + "phpstan/phpstan": "^1.1", + "phpstan/phpstan-phpunit": "^1.0", + "phpunit/phpunit": "^9.6 || ^10.5", + "squizlabs/php_codesniffer": "^3.7", + "tecnickcom/tcpdf": "^6.5" + }, + "suggest": { + "dompdf/dompdf": "Option for rendering PDF with PDF Writer", + "ext-intl": "PHP Internationalization Functions", + "mitoteam/jpgraph": "Option for rendering charts, or including charts with PDF or HTML Writers", + "mpdf/mpdf": "Option for rendering PDF with PDF Writer", + "tecnickcom/tcpdf": "Option for rendering PDF with PDF Writer" + }, + "type": "library", + "autoload": { + "psr-4": { + "PhpOffice\\PhpSpreadsheet\\": "src/PhpSpreadsheet" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Maarten Balliauw", + "homepage": "https://blog.maartenballiauw.be" + }, + { + "name": "Mark Baker", + "homepage": "https://markbakeruk.net" + }, + { + "name": "Franck Lefevre", + "homepage": "https://rootslabs.net" + }, + { + "name": "Erik Tilt" + }, + { + "name": "Adrien Crivelli" + } + ], + "description": "PHPSpreadsheet - Read, Create and Write Spreadsheet documents in PHP - Spreadsheet engine", + "homepage": "https://github.com/PHPOffice/PhpSpreadsheet", + "keywords": [ + "OpenXML", + "excel", + "gnumeric", + "ods", + "php", + "spreadsheet", + "xls", + "xlsx" + ], + "support": { + "issues": "https://github.com/PHPOffice/PhpSpreadsheet/issues", + "source": "https://github.com/PHPOffice/PhpSpreadsheet/tree/3.3.0" + }, + "time": "2024-09-29T07:04:07+00:00" + }, { "name": "phpoffice/phpword", "version": "1.3.0", diff --git a/public/write.xls b/public/write.xls new file mode 100644 index 0000000000000000000000000000000000000000..36331f756222a4814238c7f299dd246f855c50f4 GIT binary patch literal 15872 zcmeHOYiwM{bv}3Z?(V%JWj^$nXzrl?!Em476tQJ_W) zNM^t9oIA6xyAnyXMN;UlW_jk^ne&}FbLPxz_1*7uy!p!4cK?giJs+05yuTJpv5Fsn z-s|%1Mv(XZ+S(d(T}UABK0ikmVE^Ti@<{B*0{*hkOKJY+s3~_<-Gl|+$H*-P^nluj ze(~mufA*j6J$14D%YPWj{rms&ABMsE8zlM$-;W}(=1HUw=^|2u^czU6NPmK~73oVz z+mODB#PV;Ua5w($LOOSKVP;`=YBD)dr;*s+i%2_>t|8G5&Mvx2R17%2Bl-f>i^K%UF>D&8R={s_EC{vefI3LcjUnUxuNUds4B zBoE3vH6_}Dv*2HmDVdisJ8in97l|{Lf_g5Q~=QMbYCc<-P z4IY$lp#0#|hxODjjE!hz7#pea#SOQEy%qcZTu(dL9~-N|mT#`eEOL_X8!}B$5VwN=@Zt>(k6Wr6zU=n((c?yG4H5(Gi6a zrb6?d2-8o1=}B%j<+r1>FJA;1aQgglZF%EkqORkYRQ{d@`IYkR9a5!_TY%O3Nv!?V z(_l~IH`=+G9enw>bv@(T<;PbY-}hr3pNo}18vWV$jrwpAmE~_-OlI-9sLJ9ulXFj# z^0_AdoNMZb9Pd~-)y0!Y<)h!+OyJ{*Ts}{~KS+XYjRrjeHv~;Me(iMSjo`No9OB^9L(`U&DAb{*cHIp`t$3dN%Wa z=wCN4SlnnV-v*gkerx^PSl;w+s3V7XSxOUOsH2&1d@%$P& z7Kd5B*3K1vt)G}38uhH=d--3;Asj5p+8@ckifs$9>l8izNxyg)q#O`S?49&$34fQE z0kN{Of!094@s4$5>y6JP)X~pqW;?2vMeLN zwv4)vySBP4Bhza#vbqXBN;54ZO+)-~H~9>CNvjPe)cUF?Of3WNm*vV@$)tFm0y4c1j`wB}_&w^fUB5|F3T&Dkw% zyAqU{fha4(%^K;G!C;oyL=FT05Izr}*d-K9wg>QuCzOymUiB#%|4A=Hg?Qr*I5dYU-e zbXGfpt$JRCUw}gMNVJIag~Re8`2~!b!1(2yf=@(-!A zGk;8d=P;T%oPOBIb7lEyWIhqB0^l7}*V#v2o{)tL<2}Ydlz#&350Tg7~zVF~hMxfiOXD z+5G5vK!S(hAV*UBHumj!@SqOQZvuw#ZwkhxVH32P&N`>oV~@TI2eqDQ zr=U`T!N%cbe#_EF(h?l(&d(XgZ|Cc*XCLSFSPY$&55n-hHbazQQie^Aq(K;CJfNe~ z;ZFt@N*7@yo<1(X{0t*3%VA)q-YUTl@Ztt4T>z6ET1I{bxf#Jc&uB^;?UG7PlRm}d>qE)!id%1MKy*>o>sHN9~P{+=$xB(sY_lwZRC8To8g%bW!*^h z=h299cm6o+i1Qq31N$P&7<{Gio-tTokCjx8H)Ufb4Bzu_U$e;zdG`t8MIrBJIr$rhUHwko# z^D>_Cv5{FZXI7c@@G9L>b3Y4>-+{*OM&n=L8gu=sZ>A)tsLg%ugtj@U?E6p2J@S$S zwE{Q;amP}-KFb=Pml0LU>S&yXTnW}>c;r}Pm}dAW!#UmN%WXki`O3)S3aD0>|J&Rk z(7A}^vS~}Ce*ks9y~^iD$M=KY^5WPlrw6}rd=T`_TfgKb$!lXm(}C)cMtWv zeHpwYgV&S6!&L>ITD$aR@cQd`LC!o4OI)P_Tm~DJ^Hg4Tq`Z)4Q(CTox3@HU74?@S z7&FQ*aZjOC={TfTNHqEMr9Vjb5wy_H{cY2^i;`Hk*DI6;+)&BlDSgB1{`Sj zpe>Hd%f6HsN|I6q|F-Cq zPq)Elj^}*34K_2M=DOgN{#Uq?Bg?)1La>2W$ePN&D|gx#z?ToXM5dl}9);Fzy%1CFDduWdtn9MAdM zHsCm3Nsg=Cwt1XwibG3rowZ%x;@eYh&f$(@NBY*yIor_|^rP0*9#zWCIopBZv&as#?^7wiB)_I> z6Dt)V$JL(YVo2aRk2%);IO4oXzzixUv>iKP(`QpEFTavfA$V4+fWu6#0WDWVj;lXf zU?=+U*HbF;RE(N=>@v6x{R9%9ca9q;z+NzYMvarh$(=n>%E8_#<+P`q&~vt@oPy`< zN;yT(*_(2(hf3unDJSxr-jox2efpI{%Y8Jh_0Dm&80#-wLvn3vxg4&ExvHi1yWk(A zzO->d?7Q{3^utlBQNTqF*SwZ1*5pbxxhTyQ5v6v)N5{M*+heuJBp_Gt6|NN60qoje zQo&eO;SME1-uOA3NEwxv$5SfAA-?eno+^5(HBs^g|ncSZCq1mGbt$ ze{mkIRGzU0q?`na$cZRtzj zy0z$D;2cSLCEW8_-N^HZL;KLD1~Ai^bgap6xyiC!XphYeT^^?kIJOh$Lj17^(*+#c zHFRMd4&dV?xwzeh4&1LY>9GST<>Fj7a7;n2Ez@yqpc-!^(cJ=sn^?2L$c-!@O z+x7T4qQ~2gqs00gGj3{Q{*vFU-Rm)WJw~s`==B)A9;4S|^eP5zM?db?c*nkk*QVC# z^S0~rw(A3qS+URK^m&{GwGO9;e^q^n09skJImQ z`W5HVT&MiCZs|vXCh`;gehL3q;w3vO^4u>1;U_pZ?ZT=h&#fLh5Ky4Pf0I9lfw$`N zEJnECq+Gy+yAu#G!qje*jy2B%KJsm|yAvWq zGu%27J%k!uKE+ska^W6p9scEqe{F*jW1-CrL@XDgdyzn_32=4J)h?HiT)}Z=MJ%RUG}PVaXTk#i4Y3kcApigX literal 0 HcmV?d00001 diff --git a/routes/web.php b/routes/web.php index 188e914..eec769a 100644 --- a/routes/web.php +++ b/routes/web.php @@ -1,5 +1,85 @@ getActiveSheet(); + + Carbon::setLocale('tk'); + + // Define vars... + $number = random_int(1, 99); + $date = new Carbon('2024-11-08'); + $year = $date->year; + $day = $date->format('d'); + $month_as_string = $date->translatedFormat('F'); + $seller_firm_type = 'Telekeçi'; + $seller_firm_name = 'Nurmuhammet Allanov Parahatowiç'; + $seller_ssb = '201126532321'; + $seller_bank_name = 'Türkmenistanyň „Halkbank“ paýdarlar täjirçilik banky'; + $seller_bank_number = "23206934160169902250000"; + + // Cell vars... + $hasap_faktura = 'Hasap-faktura № ' . $number; + $sene = sprintf('%s ýylyň «%s» %s', $year, $day, $month_as_string); + $satyjy = sprintf('Satyjy: %s %s', $seller_firm_type, $seller_firm_name); + + $satyjy_salgyt_belgi = new RichText(); + $satyjy_salgyt_belgi + ->createTextRun('Satyjynyň şahsy salgyt belgisi: ') + ->getFont() + ->setName('Times New Roman') + ->setSize(10); + + $satyjy_salgyt_belgi + ->createTextRun($seller_ssb) + ->getFont() + ->setBold(true) + ->setName('Times New Roman') + ->setSize(10); + + $satyjy_bank_maglumatlary = new RichText(); + $satyjy_bank_maglumatlary + ->createTextRun(sprintf('Satyjynyň bankynyň ady %s, hasap № ', $seller_bank_name)) + ->getFont() + ->setName('Times New Roman') + ->setSize(10); + + $satyjy_bank_maglumatlary + ->createTextRun($seller_bank_number) + ->getFont() + ->setBold(true) + ->setName('Times New Roman') + ->setSize(10); + + // Set cell vars... + $worksheet->getCell('C6')->setValue($hasap_faktura); + $worksheet->getCell('C7')->setValue($sene); + $worksheet->getCell('A9')->setValue($satyjy); + $worksheet->getCell('A11')->setValue($satyjy_salgyt_belgi); + $worksheet->getCell('A12')->setValue($satyjy_bank_maglumatlary); + + $worksheet->getCell('A13')->setValue(sprintf('şäherde (etrapda) %s BAB %s bankyň kor.hasap %s', 'Aşgabat', '390101601', '21101934110100700005000')); + + $worksheet->getCell('A16')->setValue(sprintf('Satyn alyjy: %s', 'Türkmenistanyň „Türkmenbaşy“ paýdarlar täjirçilik banky')); + + $worksheet->getCell('A18')->setValue(sprintf('744000 Aşgabat ş., Çandebil şaýoly köç., 121,')); + + $worksheet->getCell('A19')->setValue(sprintf('Alyjynyň bankynyň ady %s %s', 'Türkmenistanyň Merkezi Banky', 'Aşgabat ş.')); + + $worksheet->getCell('A20')->setValue(sprintf('Satyn alyjynyň şahsy salgyt belgisi %s, MFO %s, Hasap № %s', '101301000408', '390101304', '21101934110100300007000')); + + $writer = IOFactory::createWriter($spreadsheet, 'Xls'); + $writer->save('write.xls'); + + return 'F'; +});