ऑरेलिया - संवाद

ऑरेलिया संवाद (मोडल) विंडो को लागू करने का एक तरीका प्रदान करता है। इस अध्याय में, हम आपको बताएंगे कि इसका उपयोग कैसे करना है।

चरण 1 - एक संवाद प्लगइन स्थापित करें

संवाद प्लगइन से स्थापित किया जा सकता है command prompt खिड़की।

C:\Users\username\Desktop\aureliaApp>jspm install aurelia-dialog

इस प्लगइन को काम करने के लिए, हमें मैन्युअल बूटस्ट्रैपिंग का उपयोग करने की आवश्यकता है। हमने इसे कॉन्फ़िगरेशन अध्याय में शामिल किया है। के भीतरmain.js फ़ाइल, हमें जोड़ने की जरूरत है aurelia-dialog लगाना।

main.js

export function configure(aurelia) {
   aurelia.use
   .standardConfiguration()
   .developmentLogging()
   .plugin('aurelia-dialog'); 

   aurelia.start().then(() => aurelia.setRoot());
}

चरण 2 - फ़ोल्डर और फ़ाइलें बनाएँ

सबसे पहले, हम एक नई निर्देशिका बनायेंगे modal। इसे अंदर रखेंcomponentsफ़ोल्डर। को खोलोcommand prompt और निम्न कोड चलाएँ।

C:\Users\username\Desktop\aureliaApp\src\components>mkdir modal

इस फ़ोल्डर में, हम दो नई फाइलें बनाएंगे। ये फाइलें प्रतिनिधित्व करेंगीview तथा view-model हमारे मोडल के लिए।

C:\Users\username\Desktop\aureliaApp\src\components\modal>touch my-modal.html
C:\Users\username\Desktop\aureliaApp\src\components\modal>touch my-modal.js

चरण 3 - एक मॉडल बनाएं

पहले, चलो जोड़ते हैं view-modelकोड। हमें आयात और इंजेक्शन लगाने की आवश्यकता हैdialog-controller। इस नियंत्रक का उपयोग मोडल विशिष्ट कार्यात्मकताओं को संभालने के लिए किया जाता है। निम्नलिखित उदाहरण में, हम इसे एक क्षैतिज क्षैतिज रूप से केंद्रीकृत करने के लिए उपयोग कर रहे हैं।

मेरी-modal.js

import {inject} from 'aurelia-framework';
import {DialogController} from 'aurelia-dialog';

@inject(DialogController)

export class Prompt {
   constructor(controller) {
      this.controller = controller;
      this.answer = null;

      controller.settings.centerHorizontalOnly = true;
   }
   activate(message) {
      this.message = message;
   }
}

viewकोड इस तरह दिखेगा। क्लिक किए जाने वाले बटन मोडल को खोलेंगे या बंद करेंगे।

मेरी-modal.html

<template>
   <ai-dialog>
      <ai-dialog-body>
         <h2>${message}</h2>
      </ai-dialog-body>

      <ai-dialog-footer>
         <button click.trigger = "controller.cancel()">Cancel</button>
         <button click.trigger = "controller.ok(message)">Ok</button>
      </ai-dialog-footer>	
   </ai-dialog>	
</template>

चरण 4 - ट्रिगर एक मोडल

अंतिम चरण हमारे मोडल को ट्रिगर करने के लिए एक फ़ंक्शन है। हमें आयात और इंजेक्शन लगाने की आवश्यकता हैDialogService। इस सेवा में विधि हैopen, जहां से हम गुजर सकते हैं view-model से my-modal फ़ाइल और model, इसलिए हम गतिशील रूप से डेटा को बांध सकते हैं।

app.js

import {DialogService} from 'aurelia-dialog';
import {inject} from 'aurelia-framework';
import {Prompt} from './components/modal/my-modal';

@inject(DialogService)

export class App {
   constructor(dialogService) {
      this.dialogService = dialogService;
   }
   openModal() {
      this.dialogService.open( {viewModel: Prompt, model: 'Are you sure?' }).then(response => {
         console.log(response);
			
         if (!response.wasCancelled) {
            console.log('OK');
         } else {
            console.log('cancelled');
         }
         console.log(response.output);
      });
   }
};

अंत में, हम एक बटन बनाएंगे ताकि हम कॉल कर सकें openModal समारोह।

app.html

<template>
   <button click.trigger = "openModal()">OPEN MODAL</button>
<template>

अगर हम ऐप चलाते हैं, तो हम क्लिक कर सकते हैं OPEN MODAL बटन एक नई मोडल विंडो को ट्रिगर करने के लिए।