TaigaUIのAddOnDocモジュールを使用してAngularプロジェクトを迅速かつ便利に文書化する方法

ねえ!私の名前はアレクサンダーです。私はEuroplanWeb製品に取り組んでいます。約50人のWeb開発者、30を超える戦略的プロジェクト、継続的なオンボーディングプロセス、および関連チームの同僚の関与があるため、コンポーネントライブラリのドキュメントは迅速に適応するのに役立ちます。





この記事では、Angularプロジェクトを文書化する方法について説明し、TaigaUIのAddOnDocを使用してこれを行う方法を示します。クリエイター自身、AlexanderInkinRomanSedov、これはレゴのコンストラクターだと言います。実際、プロジェクトで使用できる便利なモジュールがたくさんあります。この記事では、AddOnDocモジュールを見ていきます





プロジェクトを文書化する理由

通常、コンポーネントのライブラリについて話すときは、設計システムから話を始めるのが好きです。設計システムは、製品の速度と品質を向上させるものです。通常、設計システムは次のコンポーネントで構成されます。





  • ガイドライン、スタイル、ルール、推奨事項。





  • figma /スケッチ/フォトショップで紹介されたUIKIT;





  • コード形式の既製のコンポーネントのライブラリ(角度、反応など)。





, . Figma . . . , /// . 20- , , , . . :





















:





















  • Angular (, , )





:





  • State









  • , ( vscode, Chrome ..)





.





Storybook – open-source .





:





  • Angular, React, Vue, Svelte, Ember

















  • open-source





:





  • , , API (Template , props, Template.bind({}) )









bit.dev - , .





:









  • ci/cd,









  • (bundle-size, dependencies ..)





:









  • : ,





AddOnDoc - open-source .





:





  • , ,





  • , Angular





  • open-source





  • ,





AddOnDoc

highlight.js. , 191 . 6 18 github. , taiga ui .





Angular workspace . – , – . Workspace . workspace . , . ci/cd gitlub. , , .





AddOnDoc

taiga-ui





npm i @taiga-ui/{cdk,core,kit}
npm i @taiga-ui/addon-doc
      
      



AppModule:





{
        provide: HIGHLIGHT_OPTIONS,
        useValue: {
            coreLibraryLoader: () => import('highlight.js/lib/core'),
            lineNumbersLoader: () => import('highlightjs-line-numbers.js'),
            languages: {
                typescript: () => import('highlight.js/lib/languages/typescript'),
                scss: () => import('highlight.js/lib/languages/scss'),
                xml: () => import('highlight.js/lib/languages/xml'),
            },
        },
    },

      
      







imports: [
    CommonModule,
    ...
    TuiDocExampleModule,
    TuiDocPageModule,
    TuiDocDocumentationModule,
    TuiDocCodeModule,
    TuiDocDemoModule
  ],

      
      







<tui-doc-page header='Money' path='npm' package ='cdk'>
  <div class='page'>
    Money &nbsp;&mdash;      input.
  </div>
  <tui-doc-example id='base' heading='Simple money' [description]='description' [content]='example1' >
    <div>
      <fo-money
        [(ngModel)]='periodSum'
        [allowNull]='true'
        [onBlur]='true'
        showingMaxFractionDigits='1.0-0'
        editorMaxFractionDigits='1.0-0'
        placeholder=''
      ></fo-money>
    </div>
  </tui-doc-example>
</tui-doc-page>
      
      



tui-doc-page - .





:





  • header -





  • package -





tui-doc-example - . .





:





  • content - TypeScript Html. //, html





  • heading -





  • description -





const example1Html = require('!!raw-loader!./examples/1/template.html').default as string;

@Component({
  selector: 'fo-money-demo',
  templateUrl: './money-demo.component.html',
  styleUrls: ['./money-demo.component.scss'],
  changeDetection: ChangeDetectionStrategy.OnPush
})
export class MoneyDemoComponent implements OnInit {
  periodSum = 32434;
  example1 = {
    TypeScript: `@NgModule({
      imports: [
        CommonModule,
        MoneyModule
      ],
      exports: [ResizabledemoComponent],
      declarations: [ResizabledemoComponent]
    })`,
    HTML: example1Html,
  };
  constructor() { }

  ngOnInit() {
  }

}

      
      



AddOnDoc





AddOnDoc TaigaUIの仕組みの例
AddOnDoc Taiga UI

. taiga ui ! , , , , , , . , .








All Articles