ご存知のように、製品開発者の仕事の一部は、設計を Figma から選択したフレームワークを使用してコードに変換することであり、プロジェクトが重要な場合は複雑になる可能性があります。デザイナーから開発者への引き継ぎの本質は、開発者がデザインの画面を正確でピクセルパーフェクトなコンポーネントに実装することです。
この記事では、AWS Amplify Studio の機能を拡張して Figma からアプリケーションを構築し、コンポーネントを React にインポートします。 Amplify の助けを借りて Figma と React を接続すると、再利用可能な React コンポーネントが作成され、時間を節約し、長いコード行を書く必要がなくなります。 Figma からコードへの変換プロセスはシームレスであり、開発者はより効率的にビルドを効率化できます (これがおそらく、 Abode が数十億ドルで Figma を買収した理由です)。
このガイドを理解して完了するには、次のものが必要です。
npm install -g @aws-amplify/cli
UI キットから React コンポーネントを作成する前に、Figma プロジェクトをセットアップする必要があります。 Figma にアクセスしたら、アカウントを作成した後にAWS コミュニティにアクセスし、AWS Amplify UI キットの Figma ファイルを検索します。
「コピーを取得」をクリックして、UI キットのコピーを複製または複製します。
Amplify UI キットには、事前に作成されたページがいくつかインストールされています。
プリミティブページ: このページは、ビルド済みコンポーネントのすべてのスタイルを含む AWS Amplify Studio にバインドします。このページのコンテンツを変更すると、Figma コンポーネントの React UI ライブラリの外観に影響します。
My Components ページ: このページでは、コンポーネントを編集、変更、および作成するためのコントロールが提供され、ビルド済みのコンポーネントが付属しています。
サンプルページ: このページには、[マイ コンポーネント] ページからのいくつかのカスタム コンポーネントのサンプル デザインが表示されます。
このチュートリアルでは、[マイ コンポーネント] ページの 2 つのコンポーネント ( NavBarとFormCheckout UI) を使用します。
Figma でのセットアップが完了したら、AWS コンソールに移動して、新しい Amplify プロジェクトを作成します。アカウントにログインし、AWS Amplify を検索します。
サービスのリストから AWS Amplify を選択します。 [すべてのアプリ] ダッシュボードで、[新しいアプリ] ボタンをクリックし、ドロップダウンから [アプリのビルド] を選択します。
アプリに名前を付け、[展開の確認] をクリックしてアプリを作成します。
Amplify プロジェクトをデプロイしたら、新しい React アプリを作成しましょう。
新しい React アプリをスキャフォールディングするには、ターミナルに移動して次のコマンドを貼り付けます。
npx create-react-app no-code
このコマンドは、美しくスケーラブルな Web アプリケーションを構築するために必要なすべてのファイルとフォルダーを解凍します。
React アプリをインストールしたら、プロジェクトを起動します。ローンチ スタジオをクリックして、ノー コードのステージングを表示します。
ノーコードのステージング環境を示すページに移動するので、スタジオの起動ボタンをクリックします。
ここでは、データ モデルの作成や認証など、さまざまなことができます。ただし、ここでは [デザイン] タブの UI ライブラリに焦点を当てます。
[開始する] ボタンをクリックします。
Figmaと同期。このダイアログ ボックスでは、マイ コンポーネント ページから Figma ファイル リンクを貼り付けることができます。
この手順を初めて実行する場合は、Figma アカウントにアクセスするために認証が必要になる場合があります。
Figma からプルされたコンポーネントのすべての変更を受け入れます。
Amplify Studio で Figma ファイルからすべての UI コンポーネントを表示できます。
Figma のインポートされたコンポーネントからのFormCheckoutは、Amplify Studio で表示されるものと同じです。
Amplify Studio で取得した UI コンポーネントを取得したので、React アプリケーションにすべての UI コンポーネントを含める必要があります。
アプリを Amplify Studio に接続するには、ローカル セットアップ手順のリンクを使用してコンポーネントをソース コードに取り込み、プロジェクトのルート フォルダーからコマンドを実行する必要があります。
このコマンドを機能させるには、前提条件セクションに記載されているように、AWS Amplify CLI をグローバルにインストールしてください。
コマンドを実行すると、プログラムに認証メッセージが表示されます。
[はい] をクリックして、React アプリにアクセス許可を付与します。その後、コンポーネントをプルするときに一連のプロンプトが表示されます。質問に対するデフォルトを受け入れます。
ターミナルで課題やエラー ログ メッセージが表示される場合は、AWS を構成していない可能性があります。
この課題に直面している場合は、このガイドを確認してください。
インストールにより、 srcディレクトリに新しいフォルダーui-componentsが作成されます。このフォルダーには、Amplify Studio からプルされたすべての UI コンポーネントが含まれています。
Amplify UI React ライブラリは、他のすべての CSS ユーティリティ ライブラリと同様に、アプリのスタイリングの目的に不可欠です。
次のコマンドを実行します。
npm install @aws-amplify/ui-react aws-amplify
スタイル
アプリケーションのエントリ ポイントである index.js ファイルで、CSS ファイルをインポートします。アプリのルック アンド フィールを担当する次のコードを使用して、index.js ファイルをコピーして更新します。
// src/index.js
import React from 'react' ; import ReactDOM from 'react-dom/client' ; import App from './App' ; import '@aws-amplify/ui-react/styles.css' ; // add this
const root = ReactDOM.createRoot( document .getElementById( 'root' )); root.render( < React.StrictMode >
< App />
</ React.StrictMode >
);
フォント
Amplify UI は、Amplify UI の依存関係のインストール中にデフォルトのフォントInterで出荷されます。の中に
public/index.html
ファイル内の次の Google フォント CDN リンクをコピーして貼り付けます。 <head>
エレメント: // public/index.html
... <head> < link rel = "preconnect" href = "https://fonts.googleapis.com" />
< link rel = "preconnect" href = "https://fonts.gstatic.com" crossorigin />
< link
href = "https://fonts.googleapis.com/css2?family=Inter:slnt,wght@-10..0,100..900&display=swap"
rel = "stylesheet"
/>
</head> ...
コンポーネントFormCheckoutおよびNavBarを表示するには、
src/App.js
ファイルを作成し、すべてのコードを削除します。次に、次のコードでファイルを更新します。
// src/App.js
import { FormCheckout, NavBar } from './ui-components' ; const App = () => { return ( <>
< NavBar />
< FormCheckout marginTop = '5em' />
</>
); } export default App;
margin-top プロパティは、ナビゲーション バーとチェックアウト フォームの間に上部の余白を与えます。 CSS 値は、コンポーネントで Amplify UI のスタイルを使用する方法の一部です。
React には、ファイルが更新されるたびに更新されるホット リロード機能が付属しています。
次のコマンドを実行します。
npm start
開発サーバーは次の場所で実行されます
http://localhost:3000
. この React アプリを Web にデプロイしたいですか? AWS Amplify を使用して段階的にガイドするこのリソースを確認してください。
Amplify Studio が提供するのは、コードがゼロまたはまったくないローコード ツールです。コンポーネントをゼロから作成したり、デザイナーから画面を実装したりすることなく、作業の一部が行われるため、このツールは開発者としての作業をエキサイティングにします。
デザイナーから開発者への引き継ぎはシームレスであると断言できます。
この記事では、Amplify Studio の助けを借りて Figma コンポーネントを作成および統合し、コンポーネントを作業アプリとして機能する React コンポーネントに接続する方法を説明しました。
完全なソース コードは、このGitHub リポジトリにあります。