راهنمای افزودن پروژه وب به پروژه Appsan

راهنمای افزودن پروژه وب به پروژه Appsan

محتوای این آموزش در حال توسعه می باشد و در نسخه های پابلیش شده در دسترس نیست.

در این راهنما، نحوه افزودن یک پروژه وب به پروژه Appsan به صورت گام‌به‌گام توضیح داده می‌شود. با استفاده از این راهنما، شما می‌توانید پروژه‌های وب خود را به‌طور مؤثری درون Appsan ادغام کرده و از قابلیت‌های جدید عنصر web-page بهره‌مند شوید.

۱. ایجاد پوشه‌های مورد نیاز

  1. ایجاد پوشه web:

    • ابتدا در مسیر اصلی پروژه Appsan خود، یک پوشه به نام web ایجاد کنید.
    • این پوشه قرار است حاوی کد منبع پروژه‌های وب شما باشد.
  2. ایجاد پوشه webdist:

    • در کنار پوشه web، یک پوشه دیگر به نام webdist ایجاد کنید.
    • این پوشه قرار است فایل‌های ساخته شده (build) پروژه‌های وب شما را نگهداری کند.

۲. اضافه کردن پروژه وب به پوشه web

  1. ایجاد پوشه برای پروژه وب:

    • درون پوشه web، یک پوشه جدید به نام پروژه وب خود ایجاد کنید. به عنوان مثال، اگر پروژه وب شما "MyWebProject" نام دارد، یک پوشه به نام MyWebProject بسازید.
  2. افزودن کد منبع:

    • تمام فایل‌های مرتبط با پروژه وب خود را درون این پوشه کپی کنید. این شامل HTML، CSS، JavaScript و هر فایل دیگری است که برای پروژه وب شما نیاز است.

۳. ساخت پروژه وب

  1. ساخت پروژه:

    • با استفاده از ابزار ساخت مناسب (مانند Webpack، Parcel، یا ابزارهای دیگر)، پروژه وب خود را بسازید.
    • نتیجه ساخت (فایل‌های build شده) باید شامل فایل‌های HTML، CSS، و JavaScript بهینه شده باشد.
  2. کپی فایل‌های ساخته شده به webdist:

    • پس از ساخت پروژه، تمامی فایل‌های ساخته شده را درون پوشه‌ای با همان نام پروژه در webdist کپی کنید.
    • برای مثال، اگر پروژه شما "MyWebProject" نام دارد، فایل‌های ساخته شده باید در مسیر webdist/MyWebProject قرار گیرند.

۴. استفاده از عنصر web-page در پروژه Appsan

  1. افزودن عنصر web-page به فایل XML:

    • حالا می‌توانید از عنصر web-page در فایل XML پروژه Appsan خود استفاده کنید.
    • ویژگی src را به نام پوشه پروژه در webdist تنظیم کنید و ویژگی title را نیز به دلخواه مقداردهی کنید.

    مثال:

    <web-page src="MyWebProject" title="پروژه وب من"/>
    
  2. تست و اشکال‌زدایی:

    • پروژه Appsan خود را اجرا کرده و بررسی کنید که صفحه وب به درستی بارگذاری می‌شود.
    • در صورت وجود هر گونه اشکال، به مسیرهای پروژه در پوشه‌های web و webdist و همچنین تنظیمات ساخت پروژه وب خود مراجعه کنید.

نکات مهم

این راهنما به شما کمک می‌کند تا پروژه‌های وب خود را به‌طور مؤثر در پروژه‌های Appsan ادغام کنید و از قابلیت‌های جدید آن بهره‌مند شوید.

راهنمای تنظیم پروژه Angular برای استفاده در Appsan

راهنمای تنظیم پروژه Angular برای استفاده در Appsan

در این راهنما، نحوه تنظیم پروژه Angular به گونه‌ای که فایل‌های ساخته شده (build) آن به پوشه webdist در پروژه Appsan منتقل شوند و همچنین پروژه Angular در پوشه web مدیریت شود، توضیح داده می‌شود. این تنظیمات به شما امکان می‌دهند که به راحتی از پروژه Angular خود در Appsan استفاده کنید.

۱. ایجاد پوشه‌های مورد نیاز

  1. ایجاد پوشه web:

    • ابتدا در مسیر اصلی پروژه Appsan خود، یک پوشه به نام web ایجاد کنید.
    • این پوشه قرار است حاوی کد منبع پروژه‌های وب شما باشد.
  2. ایجاد پوشه برای پروژه Angular:

    • درون پوشه web، یک پوشه جدید به نام پروژه Angular خود ایجاد کنید. به عنوان مثال، اگر پروژه Angular شما "MyAngularProject" نام دارد، یک پوشه به نام MyAngularProject بسازید.

۲. ایجاد پروژه Angular در پوشه web

  1. ایجاد پروژه Angular در مسیر مناسب:

    • به پوشه‌ای که در مرحله قبل در web ایجاد کردید بروید (web/MyAngularProject) و پروژه Angular جدید خود را در این مسیر ایجاد کنید.
    • برای ایجاد پروژه در مسیر خاص، می‌توانید از دستور زیر استفاده کنید:
    ng new MyAngularProject --directory web/MyAngularProject
    
  2. تست پروژه:

    • قبل از انجام تغییرات، پروژه را به صورت محلی با استفاده از ng serve تست کنید تا از صحت عملکرد آن مطمئن شوید.

۳. تنظیم مسیر خروجی (outputPath) در angular.json

  1. باز کردن فایل angular.json:

    • در ریشه پروژه Angular خود، فایل angular.json را باز کنید.
  2. یافتن تنظیمات outputPath:

    • در بخش architect و زیر بخش build، تنظیماتی به نام outputPath را پیدا کنید. این بخش مشخص می‌کند که فایل‌های ساخته شده پروژه در کجا ذخیره شوند.
  3. تغییر مسیر خروجی:

    • مقدار outputPath را به ../../webdist/[web-folder-name] تغییر دهید. به جای [web-folder-name]، نام پوشه‌ای که برای پروژه وب خود در webdist استفاده خواهید کرد را قرار دهید.
    • به عنوان مثال، اگر نام پروژه شما "MyAngularProject" است، تنظیمات باید به شکل زیر باشد:
    "outputPath": "../../webdist/MyAngularProject"
    

۴. تنظیم baseHref برای پروژه Angular

برای اطمینان از اینکه منابع پروژه به درستی بارگذاری می‌شوند، باید baseHref را به ./ تغییر دهید. این کار را می‌توانید به دو روش انجام دهید:

  1. تنظیم baseHref از طریق خط فرمان:

    • هنگام ساخت پروژه، می‌توانید از دستور زیر استفاده کنید:
    ng build --base-href ./
    
  2. تنظیم baseHref در angular.json:

    • به جای استفاده از خط فرمان، می‌توانید baseHref را به طور دائم در فایل angular.json تنظیم کنید.
    • به بخش architect و زیر بخش build بروید و مقدار baseHref را به ./ تغییر دهید:
    "build": {
      "options": {
        "outputPath": "../../webdist/MyAngularProject",
        "baseHref": "./"
      }
    }
    

۵. ساخت پروژه Angular

  1. ساخت پروژه:

    • پس از اعمال تغییرات در angular.json و تنظیم baseHref، با استفاده از دستور ng build پروژه خود را بسازید.
    • فایل‌های ساخته شده باید در پوشه‌ای با نام پروژه در webdist ذخیره شوند.
  2. بررسی فایل‌های ساخته شده:

    • به پوشه webdist در پروژه Appsan خود بروید و بررسی کنید که فایل‌های ساخته شده به درستی در مسیر webdist/[web-folder-name] قرار گرفته باشند.

۶. استفاده از پروژه Angular در Appsan

  1. افزودن عنصر webpage در فایل XML:

    • از عنصر webpage در پروژه Appsan خود استفاده کنید و ویژگی src را به نام پوشه‌ای که پروژه Angular در webdist ذخیره شده است، تنظیم کنید.

    مثال:

    <webpage src="MyAngularProject" title="پروژه Angular من"/>
    
  2. اجرای پروژه Appsan:

    • پروژه Appsan خود را اجرا کنید و مطمئن شوید که پروژه Angular به درستی بارگذاری می‌شود.

نکات مهم

این راهنما به شما کمک می‌کند تا پروژه‌های Angular خود را به‌طور کارآمد در پروژه‌های Appsan ادغام کنید و از قابلیت‌های جدید این چارچوب بهره‌مند شوید.

استفاده از کتابخانه JavaScript اپسان (AppsanWeb) برای توسعه‌دهندگان

کتابخانه JavaScript اپسان وب با هدف تسهیل ارتباط بین صفحات وب و پلتفرم اپسان طراحی شده است. این مستند به شما کمک می‌کند تا از این کتابخانه در وب‌سایت‌های خود استفاده کنید.

نصب کتابخانه

برای نصب کتابخانه اپسان، کافی است از npm استفاده کنید:

npm i @appsan-web/mini-web-sdk

لینک کتابخانه

راه‌اندازی کتابخانه

در ابتدا نیاز است که کتابخانه را در پروژه خود وارد کنید:

import {AppsanWeb} from '@appsan-web/mini-web-sdk';

استفاده از کلاس AppsanWeb

کلاس اصلی برای تعامل با اپسان، AppsanWeb است. این کلاس مسئول مدیریت ارتباطات بین وب‌سایت شما و صفحه اپسان است.

1. راه‌اندازی اولیه:

برای راه‌اندازی کتابخانه کافی است تابع initialize را فراخوانی کنید. این تابع به صورت خودکار کتابخانه را بعد از بارگذاری کامل صفحه وب شما فعال می‌کند.

AppsanWeb.initialize();

2. وضعیت آماده بودن اپسان:

می‌توانید با استفاده از getStatus() وضعیت آماده بودن اپسان را بررسی کنید. این تابع یک BehaviorSubject از نوع استرینگ باز می‌گرداند که می‌توانید به تغییرات آن گوش دهید:

const status$ = AppsanWeb.getStatus();
status$.subscribe(status => {
  console.log("Appsan Status:", status);
});

:وضعیت میتواند یکی از مقادیر زیر باشد

"not ready"
"ready"
"not available"
"error"

3. اجرای اکشن در اپسان:

تابع runAction برای اجرای اکشن در اپسان استفاده می شود.

AppsanWeb.runAction('myAction').subscribe();

4. مدیریت دکمه بازگشت:

برای کنترل رفتار دکمه بازگشت از متد setCustomBackHandler استفاده کنید در حالت پیشفرض اپسان هیستوری مینی وب شما را مدیریت میکند و این تابع تنها برای مدیریت پیشرفته ی بازگشت استفاده می شود.

AppsanWeb.setCustomBackHandler(() => {
  // Custom back behavior
});

5. ارسال درخواست HTTP:

برای ارسال درخواست HTTP می‌توانید از متد httpCall استفاده کنید. به این صورت:

AppsanWeb.httpCall('https://api.example.com', 'GET', {}, {}).subscribe(response => {
  console.log('HTTP Response:', response);
});

6. دریافت اطلاعات بایند (Bind)

متد getBind برای دریافت اطلاعات یک بایند (Bind) خاص از اپسان استفاده می‌شود. این متد یک Subject برمی‌گرداند که می‌توانید به آن subscribe کنید تا اطلاعات بایند را دریافت کنید:

AppsanWeb.getBind('myBind').subscribe(data => {
  console.log('Bind data:', data);
});

7. تنظیم مقدار متغیر

با استفاده از متد setVariable می‌توانید مقدار یک متغیر را در اپسان تنظیم کنید.

AppsanWeb.setVariable('variableId', 'newValue').subscribe();

8. دریافت مقدار متغیر

برای دریافت مقدار یک متغیر از اپسان از متد getVariable استفاده می‌کنید. این متد نیز یک Subject برمی‌گرداند که می‌توانید مقدار متغیر را با آن دریافت کنید:

AppsanWeb.getVariable('variableId').subscribe(variable => {
  console.log('Variable:', variable);
});

تنظیم امکان بازگشت و رفتار دگمه بازگشت در اپسان

تنظیم امکان بازگشت و رفتار دگمه بازگشت در اپسان

مقدمه

در این راهنما، به نحوه‌ی مدیریت رفتار دکمه بازگشت در اپسان وب پرداخته می‌شود. اپسان وب به توسعه‌دهندگان اجازه می‌دهد تا امکان بازگشت و عملکرد دکمه بازگشت را سفارشی کنند و یا از رفتار پیش‌فرض آن استفاده کنند.


استفاده از رفتار پیش‌فرض

رفتار پیش‌فرض اپسان بر اساس تعداد صفحات موجود در تاریخچه عمل می‌کند:

  1. بسته شدن اپلیکیشن: اگر تعداد صفحات موجود در تاریخچه برابر یا کمتر از یک باشد، اپلیکیشن بسته می‌شود.
  2. بازگشت به صفحه قبلی: اگر تاریخچه بیشتر از یک صفحه داشته باشد، به صفحه قبلی بازمی‌گردد. در صورت تعریف customBackHandler این تابع بجای رفتار پیشفرض بازگشت به صفحه ی پیشین اجرا میشود.

پاک کردن تاریخچه

برای پاک کردن تاریخچه و تنظیم تعداد صفحات موجود، می‌توانید از تابع پیش‌فرض clearBackStack استفاده کنید:

  1. این تابع تمام صفحات را حذف کرده و تاریخچه را به حالت اولیه تنظیم می‌کند.
  2. برای استفاده از این تابع، می‌توانید آن را در هر تابعی که نیاز دارید فراخوانی کنید.
AppsanWeb.getAvailableHistoryCountProvider()?.clearBackStack();

قابلیت customBackHandler در AppsanWeb

AppsanWeb شامل یک متغیر و متد برای مدیریت بازگشت سفارشی است:

  1. تعریف customBackHandler: این متغیر می‌تواند یک تابع تعریف شده توسط شما را ذخیره کند که هنگام فشار دادن دکمه بازگشت، اجرا خواهد شد.

  2. متد setCustomBackHandler: برای تنظیم یک تابع سفارشی استفاده می‌شود:

    AppsanWeb.setCustomBackHandler(() => {
      // handle back here your way
    });
    

در صورت استفاده از تابع شخصی سازی شده عملکرد بازگشت پیش فرض اجرا نمی شود و بازگشت میتوند با استفاده از اکشن app/forceback انجام شود. دقت کنید تابع customBackHandler تنها در صورتی که مینی اپ امکان بازگشت داشته باشد صدا می شود. در صورتی که مقدار getAvailableBackHistoryCount() یک یا کم تر باشد مینی وب بدون اجرای تابع customBackHandler بسته می شود. توضیحات تکمیلی تابع getAvailableBackHistoryCount در بخش بعدی آمدهاست.


سفارشی‌سازی امکان بازگشت

اگر نیاز دارید که رفتار خاصی برای امکان بازگشت تعریف کنید، می‌توانید از طریق پیاده‌سازی یک کلاس جدید که از رابط AvailableBackCountProvider ارث‌بری می‌کند، اقدام کنید. این رابط شامل دو متد زیر است:

  1. getAvailableHistoryCount(): برای دریافت تعداد صفحات موجود در تاریخچه.
  2. clearBackStack(): برای پاک کردن تاریخچه و بازنشانی به مقدار اولیه.

نمونه کد برای غیر فعال کردن بازگشت در مینی وب و بسته شدن مینی اپ در صورت بازگشت.

برای غیرفعال کردن دکمه بازگشت و بستن مینی وب، می‌توانید از یک Custom BackCountProvider استفاده کنید که به‌طور مستقیم تعداد تاریخچه را به 1 تنظیم کرده و سپس اپلیکیشن را می‌بندد.

مراحل پیاده‌سازی

  1. یک کلاس سفارشی ایجاد کنید که از رابط AvailableBackCountProvider ارث‌بری کند.
  2. متد getAvailableHistoryCount() را به گونه‌ای پیاده‌سازی کنید که همیشه مقدار 1 برگرداند.

کد نمونه

import { AppsanWeb, AvailableBackCountProvider } from "./AppsanWeb";

export class DisableBackAndCloseProvider implements AvailableBackCountProvider {
    private parent: any;

    constructor() {
        this.parent = window.parent;
        const glob = globalThis as any;
        if (glob['Appsan']) {
            this.parent = glob['Appsan'] as any;
        }
    }

    getAvailableHistoryCount(): number {
        return 1; // همیشه مقدار 1 برگردانده می‌شود تا بازگشت غیرفعال باشد
    }

    clearBackStack(): void {
      
    }
}

توضیحات

نمونه پیاده‌سازی یک ارائه‌دهنده سفارشی بازگشت

در این مثال، از customBackHandler برای نمایش یک دیالوگ تأیید قبل از بازگشت استفاده می‌کنیم. پیاده‌سازی این کلاس به گونه‌ای است که امکان بازگشت را کاملاً سفارشی کرده و تعامل با تاریخچه صفحات را کنترل می‌کند.

import { AppsanWeb, AvailableBackCountProvider } from "./AppsanWeb";

export class ConfirmableBackCountProvider implements AvailableBackCountProvider {
    private availableHistoryCount = 1;
    private parent: any;

    constructor() {
        this.parent = window.parent;
        const glob = globalThis as any;
        if (glob['Appsan']) {
            this.parent = glob['Appsan'] as any;
        }

        const self = this;

        // شنود برای تغییرات تاریخچه
        (function (history: any) {
            const pushState = history.pushState;
            history.pushState = function (state: any) {
                console.log('Push state:', state);
                self.onPushState(state);
                return pushState.apply(history, arguments);
            };
        })(window.history);

        window.addEventListener("popstate", (event) => {
            self.onPopState(event.state);
        });

        // تنظیم customBackHandler
        AppsanWeb.setCustomBackHandler(() => {
            self.showConfirmationDialog();
        });
    }

    onPopState(state: any): void {
        this.availableHistoryCount--;
        (AppsanWeb as any).instance.post((AppsanWeb as any).MESSAGE_TYPE_AVAILABLE_HISTORY_COUNT, this.availableHistoryCount);
    }

    onPushState(state: any): void {
        this.availableHistoryCount++;
        (AppsanWeb as any).instance.post((AppsanWeb as any).MESSAGE_TYPE_AVAILABLE_HISTORY_COUNT, this.availableHistoryCount);
    }

    getAvailableHistoryCount(): number {
        return this.availableHistoryCount;
    }

    clearBackStack(): void {
        this.availableHistoryCount = 1;
        (AppsanWeb as any).instance.post((AppsanWeb as any).MESSAGE_TYPE_AVAILABLE_HISTORY_COUNT, this.availableHistoryCount);
    }

    private showConfirmationDialog(): void {
        const confirmed = confirm("آیا مطمئن هستید که می‌خواهید به صفحه قبلی بازگردید؟");
        if (confirmed) {
            history.back();
        } else {
            console.log("کاربر بازگشت را لغو کرد.");
        }
    }
}

نحوه استفاده از کلاس سفارشی

برای استفاده از این کلاس در اپلیکیشن خود، مراحل زیر را دنبال کنید:

  1. ایجاد نمونه از کلاس:

    const backHandler = new ConfirmableBackCountProvider();
    
  2. ثبت رفتار بازگشت سفارشی: کلاس ConfirmableBackCountProvider به صورت خودکار از طریق AppsanWeb.setCustomBackHandler رفتار بازگشت را تنظیم می‌کند.

  3. مدیریت تاریخچه: این کلاس با متدهای onPushState و onPopState تعداد صفحات موجود در تاریخچه را مدیریت می‌کند.