Meteor - Package.js
Bu bölümde kendi meteor paketimizi nasıl oluşturacağımızı öğreneceğiz.
Bir Paket Oluşturmak
Paketin oluşturulacağı masaüstüne yeni bir klasör ekleyelim. Komut istemi penceresini kullanacağız.
C:\Users\username\Desktop\meteorApp> mkdir packagesŞimdi yukarıda oluşturduğumuz klasörde paketi oluşturabiliriz. Komut isteminden aşağıdaki komutu çalıştırın.Username Meteor Geliştirici kullanıcı adıdır ve package-name paketin adıdır.
C:\Users\username\Desktop\meteorApp\packages>meteor create --package username:package-namePaket Ekleme
Uygulamamıza yerel bir paket ekleyebilmek için, ENVIRONMENT VARIABLEbu Meteor'a paketi yerel klasörden yüklemesini söyleyecektir. Bilgisayar simgesine sağ tıklayın veproperties/Advanced system settings/Environment Variables/NEW.
Variable Name olmalı PACKAGE_DIRS. Variable Valueoluşturduğumuz klasörün yolu olmalıdır. Bizim durumumuzda,C:\Users\username\Desktop\meteorApp\packages.
Yeniden başlatmayı unutmayın command prompt yeni bir Ortam Değişkeni ekledikten sonra.
Şimdi aşağıdaki kodu çalıştırarak paketi uygulamamıza ekleyebiliriz -
C:\Users\username\Desktop\meteorApp>meteor add username:package-namePaket Dosyaları
Oluşturduğumuz pakette aşağıdaki dört dosya bulunacaktır.
- package-name-test.js
- package-name.js
- package.js
- README.md
Test Paketi (paket adı-test.js)
Meteor teklifleri tinytesttest için paket. Önce komut istemi penceresinde aşağıdaki komutu kullanarak kuralım.
C:\Users\username\Desktop\meteorApp>meteor add tinytestEğer açarsak package-name-test.jsvarsayılan test örneğini göreceğiz. Uygulamayı test etmek için bu örneği kullanacağız. Not: Meteor paketleri geliştirirken kendi testlerimizi yazmak her zaman daha iyidir.
Paketi test etmek için, bu kodu komut isteminde çalıştıralım.
C:\Users\username\Desktop>meteor test-packages packages/package-nameAşağıdaki sonucu alacağız.
 
                package.js Dosyası
Kodu yazabileceğimiz dosya budur. Paketimiz için bazı basit işlevler oluşturalım. Paketimiz konsolda bazı metinler kaydedecektir.
package / package.js
myPackageFunction = function() {
   console.log('This is simple package...');
}package-name.js Dosyası
Bu, bazı paket yapılandırmalarını ayarlayabileceğimiz dosyadır. Daha sonra geri döneceğiz, ancak şimdilik ihracat yapmamız gerekiyormyPackageFunctionböylece onu uygulamamızda kullanabiliriz. Bunu içeriye eklemeliyizPackage.onUseişlevi. Dosya böyle bir şeye benzeyecek.
paketler / paket-adı.js
Package.describe({
   name: 'username:package-name',
   version: '0.0.1',
   
   // Brief, one-line summary of the package.
   summary: '',
   
   // URL to the Git repository containing the source code for this package.
   git: '',
   
   // By default, Meteor will default to using README.md for documentation.
   
   // To avoid submitting documentation, set this field to null.
   documentation: 'README.md'
});
Package.onUse(function(api) {
   api.versionsFrom('1.2.1');
   api.use('ecmascript');
   api.addFiles('mypackage.js');
   api.export('myPackageFunction'); // We are exporting the function we created above...
});
Package.onTest(function(api) {
   api.use('ecmascript');
   api.use('tinytest');
   api.use('username:package-name');
   api.addFiles('package-name-tests.js');
});Bir Paketin Kullanılması
Şimdi nihayet arayabiliriz myPackageFunction() bizim meteorApp.js dosya.
package / package.js
if(Meteor.isClient) {
   myPackageFunction();
}Konsol, paketimizdeki metni günlüğe kaydedecektir.
 
                Daha iyi anlamak için package.js dosya yapılandırılabilir, Meteor resmi dokümantasyonundaki örneği kullanacağız.
Bu örnek bir dosyadır ...
/* Information about this package */
Package.describe({
   
   // Short two-sentence summary.
   summary: "What this does",
   // Version number.
   version: "1.0.0",
   // Optional.  Default is package directory name.
   name: "username:package-name",
   // Optional github URL to your source repository.
   git: "https://github.com/something/something.git",
});
/* This defines your actual package */
Package.onUse(function (api) {
   // If no version is specified for an 'api.use' dependency, use the
   // one defined in Meteor 0.9.0.
   api.versionsFrom('0.9.0');
   // Use Underscore package, but only on the server.
   // Version not specified, so it will be as of Meteor 0.9.0.
   api.use('underscore', 'server');
   // Use iron:router package, version 1.0.0 or newer.
   api.use('iron:[email protected]');
   // Give users of this package access to the Templating package.
   api.imply('templating')
   // Export the object 'Email' to packages or apps that use this package.
   api.export('Email', 'server');
   // Specify the source code for the package.
   api.addFiles('email.js', 'server');
});
/* This defines the tests for the package */
Package.onTest(function (api) {
   // Sets up a dependency on this package
   api.use('username:package-name');
   // Allows you to use the 'tinytest' framework
   api.use('[email protected]');
   // Specify the source code for the package tests
   api.addFiles('email_tests.js', 'server');
});
/* This lets you use npm packages in your package*/
Npm.depends({
   simplesmtp: "0.3.10",
   "stream-buffers": "0.2.5"
});