JP7490729B2 - スプレッドシートに基づくソフトウェアアプリケーションの開発 - Google Patents
スプレッドシートに基づくソフトウェアアプリケーションの開発 Download PDFInfo
- Publication number
- JP7490729B2 JP7490729B2 JP2022159385A JP2022159385A JP7490729B2 JP 7490729 B2 JP7490729 B2 JP 7490729B2 JP 2022159385 A JP2022159385 A JP 2022159385A JP 2022159385 A JP2022159385 A JP 2022159385A JP 7490729 B2 JP7490729 B2 JP 7490729B2
- Authority
- JP
- Japan
- Prior art keywords
- spreadsheet
- page
- records
- data
- data source
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000011161 development Methods 0.000 title description 102
- 238000000034 method Methods 0.000 claims description 109
- 230000002452 interceptive effect Effects 0.000 claims description 44
- 230000004044 response Effects 0.000 claims description 31
- 230000001360 synchronised effect Effects 0.000 claims description 5
- 230000006870 function Effects 0.000 description 80
- 230000009471 action Effects 0.000 description 56
- 230000001052 transient effect Effects 0.000 description 41
- 230000008859 change Effects 0.000 description 34
- 239000008186 active pharmaceutical agent Substances 0.000 description 32
- 238000012986 modification Methods 0.000 description 32
- 230000004048 modification Effects 0.000 description 32
- 230000008569 process Effects 0.000 description 27
- 230000010354 integration Effects 0.000 description 24
- 238000013502 data validation Methods 0.000 description 23
- 230000008676 import Effects 0.000 description 20
- 238000013461 design Methods 0.000 description 19
- 238000010200 validation analysis Methods 0.000 description 17
- 238000012545 processing Methods 0.000 description 15
- 230000000007 visual effect Effects 0.000 description 15
- 238000013459 approach Methods 0.000 description 12
- 230000003068 static effect Effects 0.000 description 12
- 230000001960 triggered effect Effects 0.000 description 12
- 230000008901 benefit Effects 0.000 description 11
- 238000011156 evaluation Methods 0.000 description 11
- 238000003860 storage Methods 0.000 description 11
- 238000001914 filtration Methods 0.000 description 10
- 230000000153 supplemental effect Effects 0.000 description 9
- 238000004458 analytical method Methods 0.000 description 8
- 238000004891 communication Methods 0.000 description 8
- 238000009877 rendering Methods 0.000 description 8
- 230000014509 gene expression Effects 0.000 description 7
- 238000003780 insertion Methods 0.000 description 7
- 230000037431 insertion Effects 0.000 description 7
- 238000004364 calculation method Methods 0.000 description 6
- 239000002131 composite material Substances 0.000 description 6
- 239000000284 extract Substances 0.000 description 6
- 238000013515 script Methods 0.000 description 6
- 244000035744 Hura crepitans Species 0.000 description 5
- 238000001514 detection method Methods 0.000 description 5
- 230000000694 effects Effects 0.000 description 5
- 230000002441 reversible effect Effects 0.000 description 5
- 238000009826 distribution Methods 0.000 description 4
- 238000000605 extraction Methods 0.000 description 4
- 230000003993 interaction Effects 0.000 description 4
- 230000036961 partial effect Effects 0.000 description 4
- 230000002085 persistent effect Effects 0.000 description 4
- 238000012546 transfer Methods 0.000 description 4
- 230000002776 aggregation Effects 0.000 description 3
- 238000004220 aggregation Methods 0.000 description 3
- 238000006243 chemical reaction Methods 0.000 description 3
- 238000007667 floating Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 230000008520 organization Effects 0.000 description 3
- 238000007639 printing Methods 0.000 description 3
- 238000012549 training Methods 0.000 description 3
- 238000003491 array Methods 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004422 calculation algorithm Methods 0.000 description 2
- 238000004040 coloring Methods 0.000 description 2
- 238000013479 data entry Methods 0.000 description 2
- 238000012217 deletion Methods 0.000 description 2
- 230000037430 deletion Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000000670 limiting effect Effects 0.000 description 2
- 230000000737 periodic effect Effects 0.000 description 2
- 230000003334 potential effect Effects 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 239000007787 solid Substances 0.000 description 2
- 210000003813 thumb Anatomy 0.000 description 2
- 230000003442 weekly effect Effects 0.000 description 2
- VYPSYNLAJGMNEJ-UHFFFAOYSA-N Silicium dioxide Chemical compound O=[Si]=O VYPSYNLAJGMNEJ-UHFFFAOYSA-N 0.000 description 1
- 238000009825 accumulation Methods 0.000 description 1
- 230000002730 additional effect Effects 0.000 description 1
- 230000004931 aggregating effect Effects 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000003339 best practice Methods 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 208000018747 cerebellar ataxia with neuropathy and bilateral vestibular areflexia syndrome Diseases 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 239000003086 colorant Substances 0.000 description 1
- 238000004883 computer application Methods 0.000 description 1
- 238000005094 computer simulation Methods 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000009792 diffusion process Methods 0.000 description 1
- 210000003811 finger Anatomy 0.000 description 1
- 239000012634 fragment Substances 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 238000012905 input function Methods 0.000 description 1
- 238000012432 intermediate storage Methods 0.000 description 1
- 238000005304 joining Methods 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 239000000203 mixture Substances 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 238000003825 pressing Methods 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 230000007480 spreading Effects 0.000 description 1
- 238000003892 spreading Methods 0.000 description 1
- 238000010561 standard procedure Methods 0.000 description 1
- 238000007619 statistical method Methods 0.000 description 1
- 238000005303 weighing Methods 0.000 description 1
- 230000003245 working effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/36—Software reuse
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/177—Editing, e.g. inserting or deleting of tables; using ruled lines
- G06F40/18—Editing, e.g. inserting or deleting of tables; using ruled lines of spreadsheets
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/38—Creation or generation of source code for implementing user interfaces
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Artificial Intelligence (AREA)
- Health & Medical Sciences (AREA)
- Human Computer Interaction (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- Stored Programmes (AREA)
- User Interface Of Digital Computer (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Document Processing Apparatus (AREA)
Description
関連出願への相互参照
/またはデータレコードへの参照を備え得る。システムは、ページに関する要求に応答して特定のウェブページの提示を生成し得る。さらに、システムは、ウェブアプリケーションを介してユーザ入力を受信することに応答してウェブデータストアを更新し得る。
に準拠し得る。いくつかの実施形態では、生成されたウェブデータストアは、スプレッドシートを備え得る、または逆もまた同様である。
づいて対話型ウェブアプリケーションを更新することをさらに含み得る;方法は、1つまたは複数のデータソースのデータレコードになされた1つまたは複数の変更を識別するべくスプレッドシートを分析することと、変更されたデータレコードに基づいてウェブデータストアを更新することをさらに含み得る(この場合、このような修正は、自動的に、インターバルをおいて、ユーザ入力に基づいてなどで行われ得る);方法は、1つまたは複数のデータソースに関連する少なくとも1つのデータレコードになされた1つまたは複数の変更を識別するべくスプレッドシートを分析することと、変更されたデータレコードに基づいてウェブデータストアを更新することをさらに含み得る(この場合、このような修正は、自動的に、インターバルをおいて、ユーザ入力に基づいてなどでさらに行われ得る)。
、1つまたは複数のプロセッサによって実行されるときに、さらにシステムに、1つまたは複数のデータ制約を満たすデータレコードを選択することに基づいて特定のウェブページの提示を生成させ得る。
ト・ユーザインターフェースを生成し得、スプレッドシート・ユーザインターフェースは、データレコードを、複数のセルを備える行および列の表形式で表示し、スプレッドシート・ユーザインターフェースは、ユーザがスプレッドシート・ユーザインターフェースの第2のセルの値に基づいてスプレッドシート・ユーザインターフェースの第1のセルの値を計算するべく式を定義することを可能にする。
rシステムは、特定のウェブページに関するクライアントデバイスからの要求に応答して、1つまたは複数の識別したデータソースに基づいてウェブデータストアから1つまたは複数のデータレコードを取得し、1つまたは複数の識別したユーザインターフェース・テンプレートに従ってフォーマットされる1つまたは複数の取得したデータレコードを含む特定のウェブページを提供し得る。webifierシステムは、ウェブアプリケーションを介してユーザ入力を受信することに応答してウェブデータストア(または適用できる場合はスプレッドシート)を更新し得る。
得る。第3のワークシートは、一次データソースのレコードおよび/または二次データソースのレコードの間接的なビューを含んでもよい。第3のワークシートのコンテンツは、第1のワークシートのコンテンツおよび第2のワークシートのコンテンツと同期され得る。本方法は、特定のウェブページに対応する少なくとも1つのユーザインターフェース・テンプレートに基づいて対話型ウェブアプリケーションの特定のウェブページを生成し得る。特定のウェブページは、特定のウェブページに対応する少なくとも1つのユーザインターフェース・テンプレートに基づいて識別される第3のワークシートのレコードを参照し得る。本方法は、対話型ウェブアプリケーションの特定のウェブページに関連する入力制御を介してユーザ入力を受信し、受信したユーザ入力に基づいて、かつ、決定された関係に基づいて、一次データソースおよび/または二次データソースの少なくとも1つのレコードを更新し得る。
なく、ユーザに提示するためのデータの論理配列を指す。スプレッドシートソフトウェアアプリケーション(例えば、MICROSOFT EXCEL、APPLE NUMBERS、およびGNOME GNUMERIC)は、データがグリッドの行および列に配列されるスプレッドシートをユーザが作成および編集することを可能にする良く知られたタイプのソフトウェアであり、操作するおよび計算に用いることができる。スプレッドシートソフトウェアアプリケーションはまた、コンピュータ上でローカルにまたはクラウドベースのアーキテクチャで使用可能な、データの表形式での編成、分析、およびストレージのための対話型コンピュータアプリケーションを指し得る。スプレッドシートは、集計用紙のコンピュータシミュレーションであるとも言われている。スプレッドシートソフトウェアアプリケーションは、一般に、スプレッドシートのセルに入力されたデータで動作し、スプレッドシートの各セルは、数値データ、テキストデータ、或いは数式、1つまたは複数の他のセルの内容、またはさらには外部リンクされるデータに基づく値を自動的に計算および表示する式の結果を含み得る。1つの例示的な態様によれば、スプレッドシートは、特定のスプレッドシートソフトウェアアプリケーションにより使用可能なデータファイルとして定義され得る。1つまたは複数のスプレッドシート・ドキュメントまたはデータファイルは、同じおよび/または異なるファイルから他のスプレッドシート/ワークシートのデータを参照するまたはしない場合がある複数の個々のおよび/または別個のスプレッドシート(例えば、ワークシート、タブ)を備え得る。ある点では、スプレッドシートがデータベース用途と非データベース用途との両方をサポートするのに対し、データベースが通常は1つまたは複数のインデックス付きテーブルにデータが格納されることを必要とすることに限って言えば、スプレッドシートは、データベースとは異なる。本明細書で説明される例示的な態様は、ローカルのスプレッドシートアプリケーションソフトウェアに関係し得る。しかしながら、他の例示的な態様では、スプレッドシートは、データが最終的に格納される機能またはフォーマットを提供するバックエンドのシステムアーキテクチャに関係なく、ウェブブラウザまたは他のネットワーク化されたユーザインターフェースを通じてスプレッドシート関数および特徴をユーザに提示する、クラウドベースのシステムのユーザインターフェースを介してユーザに提示され得る(例えば、GOOGLE
SHEETS、MICROSOFT OFFICE ONLINE、EditGrid、ZK Spreadsheet、Sheetster、Smartsheet、DHTMLX Spreadsheet、Webix、eXpresso、ThinkFree
Cell)。本明細書で説明される態様は、ローカルのスプレッドシートアプリケーションソフトウェア実装とクラウドベースのスプレッドシート実装との両方、または任意の他のスプレッドシート実装に適用され得る。
対話することによってセルを選択するおよびセルの内容を他のセルに移動することを可能にするユーザインターフェース、それらのセルへの参照を現在編集中のセルの式に自動的に挿入するためにユーザが1つまたは複数のセルを選択することを可能にするユーザインターフェース、他のセルが同様にスパンすることを必要とせずに単一セルまたは単一セルの内容が複数の行および/または列にわたって視覚的にスパンし得ることをユーザが指定できること、行と列が交換可能であり、したがって、データを回転された配向で入力することもできるようにデータの論理配向に対する最小の制約または無制約、フォーマットおよび値および式がセルの行全体または列全体または領域全体にわたって一貫している必要がないセル、および幅をグループとして変更することができる列、のさらなる特徴のうちの1つまたは複数を有する。すべてのこれらの特徴が、アプリケーションがスプレッドシートソフトウェアアプリケーションとなるのに必要とされるわけではない。
つまたは複数の例示的な態様を行うためのデータベースおよび制御ソフトウェアのアクセス、制御、および管理を全般的に提供する。データサーバ103は、ウェブサーバ105に接続されてよく、ウェブサーバ105を通じて、ユーザが対話するおよび要求したデータを取得する。代替的に、データサーバ103は、ウェブサーバ自体として作用し、インターネットに直接接続され得る。データサーバ103は、ネットワーク101(例えば、インターネット)を通じて、直接または間接的な接続を介して、またはいくつかの他のネットワークを介して、ウェブサーバ105に接続され得る。ユーザは、リモートコンピュータ107、109を用いて、例えば、ウェブブラウザを用いて、データサーバ103および/またはウェブサーバ105と対話し得る。クライアントコンピュータ107、109は、そこに格納されたデータにアクセスするべくデータサーバ103と共同して用いられ得る、または他の目的のために用いられ得る。例えば、クライアントデバイス107から、ユーザは、当該技術分野では公知のインターネットブラウザを用いて、またはコンピュータネットワーク(インターネットなど)上でウェブサーバ105および/またはデータサーバ103と通信するソフトウェアアプリケーションを実行することにより、ウェブサーバ105にアクセスし得る。
数のコンピュータにわたって処理負荷を分散させるために、地理的位置、ユーザアクセスレベル、サービスの品質(QoS)などに基づいてトランザクションを分離するために、複数のデータ処理デバイスにわたって分散され得る。
QUATTRO PRO、GOOGLE SHEETS、GNUMERIC、OPENOFFICE CALC、または任意の他のスプレッドシートソフトウェア、アプリケーション、および/またはドキュメントフォーマットが用いられ得る。上記のように、本明細書での態様は、ローカルのスプレッドシートアプリケーションソフトウェア実装とクラウドベースのスプレッドシート実装との両方に等しく適用され得る。
ら、ウェブページの代わりに、webifierソフトウェアは、加えて、かつ/または代替的に、特定の1つまたは複数のコンピュータ上で直接使用するための独立型のソフトウェアアプリケーションを生成してよく、これにより、ソフトウェアアプリケーションを用いるときのネットワークアクセスの必要性が軽減される。これにより、上記の方法は、カスタムのおよび/または複雑なソフトウェアアプリケーションを作成するのに用いられ得る。「複雑な」アプリケーションは、特に、データ入力、レポート、複数のユーザ、ユーザごとのセキュリティアクセス設定、ワークフロー、自動通知システム、履歴情報の保存、すべてのユーザによる変更のロギング、および/またはファイル添付などの複数の特徴を有するアプリケーションを指す。「カスタムの」アプリケーションは、要件がどれほど独自であっても特定のビジネスのニーズに合わせて構築されたソフトウェアを指し得る。このようなカスタムのアプリケーションの結果は、1つの一般的なことを行うように設計された既製の(アウト・オブ・ボックスの)ソフトウェアではないが、カスタムのアプリケーションでも多くの場合にそれを行うことができる。したがって、webifierソフトウェアは、1つの目的に縛られなくてよい。むしろ、webifierソフトウェアは、動的で融通性があり、ソフトウェアのプロダクティビティスイートなどの洗練されたソフトウェアアプリケーションを用いる平均スキルを有する誰でも用いることが可能であり、これにより、カスタムのソフトウェア開発者を雇用することに取って代わるものとして作用し得る。
理は、テンプレートシートからの値および書式設定を評価および参照すること、並びに、テンプレートシートに基づいて識別されるレコードシートからの値を評価および参照することにより、スプレッドシート定義をhtmlデスティネーションページに変換する。デスティネーションページは、訪問者のブラウザ356に送信され得る306。図3Aはさらに、訪問者が見る、テンプレートシートでのみ見受けられ、レコードシートでは見受けられないテキストラベル、RecordSheet!A1から生じるテキストラベル、RecordSheet!C2の評価からの“100”の値、およびRecordSheet、チェックボックスに関するRecordSheet!A2、およびテキストボックスに関するRecordSheet!B2からの値を有するテンプレートシートにより定義されるHTML入力制御を有するページを例示する。図3Aは、訪問者が、ブラウザ356でチェックボックスをチェックし、サブミットをクリックし、結果的にブラウザがhttp post要求307をWebifier論理コントローラ353に送信することを例示する。Webifier論理353は、メモリ305から現在のスプレッドシート定義をリロードし得る。Webifier論理353は、post要求を処理し、メモリ351を更新されたスプレッドシート定義で更新する。設計者のAdd-On357が依然としてアクティブなセッションを有する場合、Webifier論理353は、更新された部分的スプレッドシート定義、または提示されるスプレッドシート定義を更新するのに十分な変更イベントをAdd-On357に送信し308、次いで、ExcelのCOM
Interopライブラリを用いて、Add-On357は、設計者のワークシートがセルA2に“true”を表示することになるように、更新されたバージョンをスプレッドシートアプリケーション354で設計者に提示し得る309。
ンショットである。
ットである。これは、“Everything”、名前付き範囲、並びに設計者により指定されるカスタム範囲を用いるなどのエイリアスのサポートを例示する。
に基づいてデフォルト値を有するフィールド並びに編集不可フィールドを提示し得ることを例示する。
単に例示的な参照のために、スプレッドシートの2つの使用スタイルが本明細書で言及される。他のスタイルが代替的に用いられ得る。1つ目は、各レコードがシート全体または多くのシートを危険にさらすファイル全体を備えるシートレコードである。例えば、多くの会社は、作成する販売見積書毎に新しい販売見積書スプレッドシートファイルを保存する。該ファイルは、バックエンド計算に関する1つのシートと印刷可能な見積書を有することを意図する1つのシートなどのいくつかのシートを有する場合があり、印刷可能な見積書シートは、典型的に、すべて該単一の見積書を表す、テキスト、数字、および結果がテキストまたは数字となる式を含む、多くの行および列を有することになる。それらはまた、公正に読み出し可能なプリントアウトを可能にするのに十分な書式設定を含み得る。
シートはその上に付加的な行レコードシートまたは関連のないデータ(例えば、図60の列E)を有し得るが、簡単にするために、本発明者らは、全体を通して、これを依然として行レコードシートとして言及する。例えば、多くの会社は、以下のようなクライアントをリストするスプレッドシートを有することになる。シートは、“Client”および“Industry”および“Client ID”などのいくつかの列名をもつ最上行1を有し得る。その下の各行は、単一クライアントに関係したデータを有し得る。例えば、行2は、列Aに“Pleasant Solutions”、列Bに“Software Development Services”、および列Cに“1”を有し得る。行3は、列Aに“NewCo”、列Bに“Consulting”、および列Cに“2”を有し得る。名前にかかわらず、行レコードはまた、レコードが列レコードであるかのように左から右にリストされるように行および列がフリップされる目的を有するリストを表す。
ここで、例示的な実装を参照してユーザインターフェース・テンプレートに関してステップ201および205をより詳細に説明する。伝統的なスプレッドシートアプリケーション、クラウドおよびウェブベースのスプレッドシート、またはウェブアプリケーション内に埋め込まれた簡易化されたスプレッドシート・インターフェースのいずれで行われるかに関係なく、スプレッドシートツールは、訪問者またはレポートレイアウトに関する所望のユーザインターフェースを表すスプレッドシートを作成するのに用いられ得る。例えば、テンプレートは、単一の見積書に適切であろう値および式を含む多くの行および列を有する1つのシートを有することもできる:最上部付近にクライアントの大きいフォントテキストタイトル、その後に“Invoice Number”として第1の値を有する行、およびその右に実際のインボイスナンバーを表示することを意図されるセル。その下のいくつかの行は、コメントをイタリック体で表示することを意図された、複数の行および列にわたるセルを有し得る。シートの最下部付近に“Subtotal”とラベル付けされるセル、その右に、該特定のインボイスの合計を表す数字を有することを意図された、“$”記号で通貨を指定するセル書式設定を有するセル(このとき該セルはグリッド上のC15の位置を有する)。次の行は、税および税の後に合計に関係したセルを有し得るが、後でそこに配置される値を有することを意図するのではなく、税および合計セルは、“=C15*10%”などの小計セルの場所を参照するスプレッドシート式を有することになり、この場合、C15への変更は、これらの式に基づく合計に影響を及ぼすことが意図される。
LATE()”などのスプレッドシート式関数を定義し得る。式が用いられるセルは、セルのサイズに基づいてネストされるテンプレートに割り当てられるセルの場所、または幅および高さに基づいて、ネストされるテンプレートシートをどこに挿入するかなどの特定の情報を暗黙的に提供し得る。テンプレートにポピュレートするためのソースレコード(単数または複数)が親テンプレートと同じではない場合、パラメータをUSETEMPLATE関数にパスインすることもでき、これは、(さらに後述するように)ネストされていないテンプレートシートがいくつかのページタイプに関してするのとほぼ同じように、ソースデータが何であるかをテンプレートが知ることを可能にすることになる。これは、異なるレコードシート上のレコードからポピュレートされる必要がある“invoice
items”のリストをその内部に含むインボイステンプレートなどのシナリオを可能にする。典型的に、このようなネストされるテンプレートシートは、親テンプレートの行または列のアラインメントに影響を及ぼさずに十分な幅および高さを表示することを可能にするのに伝統的なスプレッドシートの“merge cells”特徴、並びに、特定のインボイスに属するこれらのインボイスアイテムのみへのレコードのフィルタリング(以下で説明される)を提供するのに伝統的なテーブル特徴を利用することになる。
スプレッドシートツールでテンプレートシートを設計している間、特定のレコードまたは多くのレコードから導出される集計値を表すことを意図しているセルは、ブランクと評価され得るおよび/または設計者に書式設定を示すこと以外のシステムへの影響を有さないプレースホルダ値を有し得る。外部リストまたはデータベースは、C15などのセルの場所の相互参照と、インボイスの小計を表示するなどのそれらの意図された目的を含み得る。代替的に、テンプレートシートからレコードシートセルが参照可能である場合、レコードを指すこれらのセルに式またはプレースホルダ式を挿入することができる。例えば、テンプレート上のクライアントタイトルセルは、“=ClientList!A1”であり、これはもしかするとプレースホルダとして設計時間中にスプレッドシートツールによってテキスト“Client”へ評価されることになり、またはおそらく、この式は、“=ClientList!A2”であって、これはもしかするとプレースホルダとして設計時間中に“Pleasant Solutions”としてスプレッドシートツールによって分解されることになる。加えて、“=ClientList!A:A”または”=ClientList!A1: A1000”を参照し、結果的に、結果的に、ブランク、エラー、または意図せぬ値を生じることがある。上記のケースのそれぞれにおいて、設計時間中に結果を生じるテキストは、設計時のプレースホルダにすぎず、訪問者に関するなどの後の時点での実際の評価中にwebifierを支援するためにClientList上のどの列がテンプレートに記入する際に用いられるべきかの有用な情報を有する式自体ほど重要ではない。便宜上、この概念は、概してTemplate Indicatorと呼ばれることがある。
可能なまたは関連する列のリストからドラッグおよびドロップすることから導出することもできる。この式は通常、スプレッドシートツールのセル参照(“ClientList!A1”または指定されたテーブルの場合、“ClientList!Client”)、この目的のために特化されたアクションをトリガする典型的な関数呼び出し構文(“=GetRowRecordData(“Client”)”)とすることができるか、またはそれらは“[[Client]]”などの特化された別個の式とすることができる。式は、スプレッドシートに典型的なようにセルに格納されてよく、またはそれらは、それらがどんなセル上に適用されるかについての情報と共に、式の特別な外部リストに格納することもできる。
設計者がレコードの一次セットを行レコードシートに持つことと、別のシート(二次データソース)の1つまたは多くの「二次レコード」を持つことを望む場合、レコードセット間の多くの種類の関係が可能である。設計者が1つまたは複数の二次データソースを指定するとき、webifierは、テンプレートシート内で見出された参照をどのようにポピュレートするかを決定するために、設計者から関係の種類を決定するための付加的な情報を要求し得る。
パラメータとしてセルをマージし、シートの外部であるが、ネストされたテンプレートまたは親テンプレートに関連するwebifier内のオプションを指定し、セルを色分けし、セルの周りの境界線を描画し、かつ/またはネストされたテンプレートの境界を表すように指定されたセルの領域を選択することによって指定することができる。テンプレートのネストは、セルの挿入をもたらし、既存のテンプレートセルを下および/または左にシフトさせて、該当する二次データ値のすべてを表示するための適切な余地を提供し得る。
いくつかの態様によれば、webifierは、設計者の作業を容易にするために、他のシートおよび/またはテンプレートに基づいてシートを自動的に生成し得る。上記のように、行レコードシートは、単一のシートの多くのレコードを整理し得る。webifierによって自動的に生成される行レコードシート、またはそれ以外の場合、スプレッドシートアプリケーションによって生成される行レコードシートは、「オートゲン」シートと称され得る。本明細書においてwebifierを参照して説明されるが、当業者であれば、以下にさらに説明される特徴を有するシートは、webifier以外のスプレッドシートアプリケーションに使用され得ることを理解するであろう。
てのビューに影響を及ぼすように変更されてもよい複数の仮想ビューが存在し得る。オートゲンシートと同様に、当業者は、本明細書に記載される仮想参照および仮想シートが、ここで論じられるwebifierの例示的な実施態様を超えて使用および用途を見出すことを理解するであろう。仮想シートを定義する際に、設計者は、フォーマット変更のすべてまたはいくつかが仮想ビューに反映されるか、またはいずれも反映されない場合に制御するためのオプション、および、オーバーライドされたセルが仮想でなくなるように、どの方向変更が直接データ値または式で反映されるか、またはオーバーライドされることが許可されるかを制御するためのオプションを指定し得る。
一例として、設計者は、データソースへのいかなる参照もせずに、データソースへの参照が追加されるためのインジケータを用いて、スプレッドシートツール内にインボイスの挿入テンプレート「InvTemplate」を作成し得る。設計者は、そのテンプレートを参照して、詳細タイプのページを作成し得る。webifierは、テンプレート内のすべてのインジケータを識別し得、設計者からのさらなる関与なしに、各インジケータがインジケータを有する場合、“InvTemplate_A1”等の列名を有する列を割り当てられる仮想行レコードシートVirtInvSheetを自動的に生成し得る。webifierはまた、VirtInvSheetをデータソースとして使用し、訪問者が任意の選択されたインボイスの詳細に移動するためのナビゲーションリンクの列を使用して、仮想レポートページを自動的に生成し得る。InvTemplateがインボイスアイテムを入力するためのネストされたテンプレートを有する場合、webifierは、第2の仮想行レコードシートVirtInvItemSheetを自動的に生成し得、これには、以前に示された設計者が各インボイスに対して一意であり、一次キーとして扱うことができるInvtemplate上のインジケータに結びつく列がある。webifierは、次いで、VirtInvItemSheetをデータソースとして、および同様のナビゲーションリンクを用いて仮想レポートページを生成し得る。また、この例では、各インボイスアイテムの販売頻度および挿入された毎月のインボイス数について自動的に生成されるページを有するように、webifierは、VirtInvSheetまたはVirtInvItemSheet内の列に基づいて集計式を有するテンプレートおよびページを自動的に生成することができる。次いで、設計者は、付加的なシートおよびページを構築し続けるために、自動生成および仮想シートならびにレポートのすべてまたは一部を参照または修正し得る。
る潜在的な曖昧さを検出するために、かつ/または設計者または訪問者からのさらなる情報の収集をトリガするために使用され得る。
Webifierは、レコードシート間、およびデータソース全般または1つまたは複数のテンプレートまたはページ定義などの特定のコンテキスト内のデータソース間の関係の存在、種類、および/または具体的な内容を自動的に検出し得る。webifierは、設計者アクション、訪問者アクション、設計者または訪問者によるレコードデータ入力、レコード構造、レコードシート上のフォーマット、テンプレート構造およびフォーマット、ページ定義、グローバルホワイトリスト、静的ブラックリスト、それをサポートするスプレッドシートツールに宣言された関係、またはMicrosoft PowerPivotなどのスプレッドシートツールプラグインを含む関係の自動検出を支援するために、利用可能な情報(「手がかり」と称され得る)の任意の組み合わせを使用するか、または分析し得る。分析の結論の信頼性を高めるために、様々な静的もしくは動的計量アルゴリズムまたはポイントシステムを使用して、複数の手がかりを一緒に分析し得る。信頼性レベルは、利用可能な手がかりの数および各手がかりの結論の一貫性を含む、手がかりのいくつかの特徴によって測定され得る。例えば、手がかりを組み合わせて、特定の関係を示唆する手がかりの数から、異なる関係を示唆する手がかりの数および/またはその特定の関係の欠如を引いた数をカウントすることによって、信頼性レベルを得ることができる。信頼性レベルは、webifierによって無言で関係を受け入れるべきか、設計者は信頼性レベルによって命令される1つまたは複数の推奨事項のうちの推奨事項として結論を明示的に確認するべきか、または、分析は結論を得るのに不十分であるとして無視されるべきであるかを判断するために使用され得る。
レコードの場合であっても、列名を含んでよい。例えば、「uid」または「インボイス番号」という名前の列は、「コメント」のブラックリスト列名よりもキーである可能性が高い。手がかりは、列と共に含まれるデータの一意性を含み得る。例えば、列が常に同じ値を有する場合、それは依然として外部キーであってもよいが、一次キーではなく、複合一次キーの一部である可能性が低い。手がかりは、列内のデータの長さを含み得る。例えば、いくつかの値に対して空白を有する列と同様に、すべての値が一意であっても、多数の単語を通常有するメモ列がキーとなる可能性は低い。手がかりは、列内のデータの一貫性を含み得る。例えば、1つの列が数値および時には単語の両方を有する場合、データ種類および長さが一貫した列と比較して、キー列である可能性は低い。手がかりは、ネストされたテンプレートを有するか、またはネストされたシートを参照するテンプレートの定義を含み得る。例えば、インボイスがインボイスアイテムのリストを有し、設計者が現在表示されているレコードのInvoiceIDに一致するネストされた列“BelongsToInvoice”によって示されるインボイスアイテムをフィルタリングすることを示す場合、BelongsToInvoiceはおそらく外部キーであり、InvoiceIDはおそらく一次キーであり、一方が他方と比較してネストされた方法で使用される事実によって、インボイスとインボイスアイテムとの間に関係がある確率が増加する。手がかりは、仮想一次キーおよびいくつかの非自動生成列を分析して、仮想一次キーと最も密接に相関する列を識別することを含み得る。手がかりは、特定の列を指定する訪問者検索の発生をカウントすること、または特定の列内の値に一致する値を指定することを含み得る。例えば、リストレポートページにおいて、訪問者が頻繁に「Inv0511」等のテキストを検索する場合、Inv0511等の値を含む列は、一次キー列である可能性が高い。手がかりは、データがどれだけシーケンシャルであるかを含み得る。例えば、ギャップのない値1~100を有する列は、両方のシートが同じテンプレートによって使用される異なるシート上の同様の列の存在とともに、両方のシートが関係を有し、両方の列が関係を有することを示唆する。手がかりは、第2のシート上の列に対する1つのシート上の列の値の分布を含み得る。例えば、シートF列Aが常にシートS列Aの値を有する1:1の分布を有する場合、第2のシートSは、シートF上のレコードに必要な詳細レコードである可能性が非常に高い。1:0-1の分布を有する場合、シートFのレコードのオプションの詳細レコードである。他のすべての列と共に1:0の分布を有する場合、シートFおよびシートSは、それらの間の関係を有さない可能性がある。手がかりは、列の位置決めを含み得る。例えば、レコードシート内の第1の列は、ミドル列と比較して一次キーである可能性が高く、または互いにすぐに隣接する列は、遠く離れた列よりも複合一次キーを形成する可能性が高い。
スプレッドシートツールの多くの従来の数式関数を用いて、二次データソースからの情報を参照することができる。webifierは、自動検出関係などの識別された関係を使用して、二次データソースからデータにアクセスする機能および方法をさらに簡素化し得る。先ほどの例の拡張として“=VLOOKUP(DetailSheet!C5,ParentSheet!B:F,3,false)”は、詳細シートと親シートとの関係が既に定義されている場合、どのような手段を介しても、webifierは詳細シート内から呼び出される場合、詳細シートと親シートの関係は、詳細シートのC列の外部キーと親シートのB列の一次キーとの関係同様に既に知られているため、詳細シート上のZ5などのセルが、“=WEBIFIERVLOOKUP(ParentSheet!D)”の簡略化された関数を使用することを可能にする。関数名は、この例と異なる場合もあれば、同じVLOOKUP( )関数名を共有するが代替パラメータと共有するオーバーロードである場合もある。
DetailSheet!A:Bでの複合外部キーと一致する行レコードに制限する、“=SUMIFS(DetailSheet!F:F,DetailSheet!A:A,CONCAT(‘=’,C5),DetailSheet!B:B、CONCAT(‘=’,D5))”に類似した従来の使用は、同じ結果を達成する、代替バージョンの“=SUMIFSWEBIFIER(DetailSheet!F:F)”と置き換えられてもよい。
タに明示的に説明された関係を有する従来のVLOOKUPがある場合、その式でテンプレートのセルを編集する訪問者は、インボイスアイテムが属する親インボイスを変更するか、またはインボイス名をフロースルー編集するつもりであるかのいずれかを意図し得る。次いで、webifierは、テンプレートセルの対応する入力制御が編集されるときにどの変更が生じるかを決定するように設計者が設定し得るページ上に「フロースルー編集を可能にする」オプションを有し得る。編集により、一次データソースが二次データソース上でどのレコードを参照するかが変更される場合、webifierは、入力の便宜上、かつ/または、制御が受け入れる値を関係を考慮して有効な値に制限するために、デスティネーション入力ページに表示される入力制御の種類を変更し得る。前の例を続けて、インボイス名を入力するのに適したテキスト制御の代わりに、レンダリングされた制御は、インボイス名を選択すると、インボイスアイテムの親をその名前に関連付けられたインボイスに変更する、すべてのインボイス名のリストを有するドロップダウンであり得る。
図2のステップ207に戻ると、スプレッドシートが適用可能なデータで要望に応じて構成されると、設計者が、1つまたは複数の例示的な実施形態に関連して本明細書で説明したwebifierソフトウェアを用いてデスティネーションシステムを構築するべくプロセスを開始することがさらに含まれ得る。ユーザは、デスティネーションシステムにログインし(図13)、スプレッドシートを受け入れる管理ウェブページを訪問し得る。例えば、webifierソフトウェアは、xlsxスプレッドシートファイル(図68)、例えば、データ129(図1)のアップロードを受け入れる入力フォームを有し得る。代替的に、webifierは、クラウドおよびウェブベースのスプレッドシートツールからweb-service APIを介して、APIがそれを可能にするならシートのグループを一度にまたはさらにはAPIがそれを必要とするならセルごとに、スプレッドシート定義をフェッチするべく統合を有し得る。簡略のため、すべてのこれらの方法は、本明細書で「アップロードする」、すなわち、スプレッドシート定義またはデータファイルをwebifierデータストア、例えば、データベース131へアップロードする(図1)として言及される。特に、レコードをアップロードするためのおよびインターフェーステンプレートをアップロードするための別個のステップは必要とされず、それらは1つのスプレッドシート定義から設計者から1つのステップで行うことができ、またはそれらは別々の時点で行われ得る。
ステップ209(図2)に関連して前述したように、結果として生じるソフトウェアは、例示的な実装に関連して本明細書で説明した1つまたは複数のウェブページを備えるウェブアプリケーションを含み得る。設計者は、webifierソフトウェアのadminインターフェースにおいて“add page”特徴を選択し(図18、図69、および図55)、様々なページタイプ(図51)および構成オプション(図52)から選択し
得る。スプレッドシート定義内のセルデータまたはメタデータは、新しいページを作成する、どんなタイプのページが設計者により意図されたか、およびそれらの種々の構成オプションの、インジケータまたは命令を含むことが可能であるが、この情報がなければ設計者は催促され得る。多様なページタイプをデスティネーションサーバ上で作成することが可能である。典型的に、すべての生成されたデスティネーションページのメニューは、web appの全体を通した便利なナビゲーションを可能にするべく、すべてのデスティネーションページ上にメニューとして表示され(図66の“Timesheet”web
appメニューは、該特定の例に関するすべての3つのデスティネーションページをリストする)、デスティネーションページは、“apps”によりグループ化されてよく、それらは典型的に、それらがどんなスプレッドシート定義またはファイルから生じたかに基づいてグループ化される、および/またはそれらを作成した設計者によりグループ化される(ログイン設計者、またはログイン設計者とスプレッドシート定義を共有した他の設計者または他のグループから)(図16)。デスティネーションシステムのメニュー内のデスティネーションページの順序は、設計者がAdd-On内からそれらの順序を変更するべくページをドラッグおよびドロップすることにより修正することができる。
webifierソフトウェアが作成し得るウェブページの1つの例示的なタイプは、“report”ページタイプである。レポートのタイトルは、ユーザにより指定され得る、またはスプレッドシートのデータまたはタイトルから生成され得る(図52)。ソースも指定され得る。ソースは、スプレッドシート定義内のシート名(図33に示すCSV_Importページタイプに関するソース制御と同様に)、“=B9:C12”などの典型的なスプレッドシートセル範囲参照(図36)、スプレッドシート内で定義されるチャートの名前(図52)、または“TotalColumn”または“PrintableArea”または“Employee List:Employee”などの名前により指すことができるセル範囲であるスプレッドシート“named range”(往々にして“defined name”として知られている)(図36)とすることができる。一般に、範囲は、連続するブロックである必要はなく、それらは、いくつかのブロックおよびセルを備え得る。例えば、“A1:A8,A10,A30:B30”。多くのページが同じソースセルを参照してよく、ソースセルは、別のページのソースと部分的に重複してよく、またはページは、組み合わされることになる一連のソースを有してよい。これは、設計者がスプレッドシートツールにおいて設計したレポートに基づいてデスティネーションシステムがHTMLウェブレポートまたはモバイル画面を訪問者に示すのに十分な構成であり得る。例えば、ClientListシートは、このとき訪問者がアクセス可能となっているリストにおける行レコードのすべてで指定することもできる。“Show Page Title”などの多数の随意的な構成が指定され得る(図28)。ページを閲覧するのにログインが要求されるかどうか(図24)、どんなログインユーザまたはユーザのグループまたはロールが、どんなデバイス、ネットワークから、またはどんな時間帯にページの閲覧を許されるかを制御するべく、appまたはページ上でパーミッションルールも指定され得る。図25は、どんなログインユーザがページの閲覧を許されるかを示す簡易化された例を示す。最終結果は、ユーザがウェブデザインの知識を有することを必要とせずに、データのレイアウトおよび書式設定(図97)を含むデータを供給するオリジナルのテンプレートスプレッドシートと似ているように見えるレポートを表示するウェブページである。
動的に追加するオプションを有し得る。例えば、“allow search”(図48)または“allow PDF export”(図示せず)オプションが、calendarページタイプなどのいくつかのページタイプ上で利用可能であり、これは結果的に、意図されたカレンダーだけでなく、サーチ結果をスクロールおよびフォーカスするなどの方法によりユーザの注目を特定のデータに引き寄せるべくサーチテキストボックスおよびサーチサブミットボタンなどの複数の制御も有するデスティネーションページを生じることができる。サーチ結果の処理は、クライアント側またはサーバ側で行われ得る。
webifierが作成することができる別のタイプのページは、例えば、例示的な実施形態に係る、上記の(図43)、ステップ211(図2)中に用いられ得る、“insert”ページタイプである。同様に、ClientListのソースが指定され、訪問者により行または列が挿入可能であることを設計者が意図するかどうかのインジケータであり得る。ヘッダの行を表すセルの範囲は、自動的に識別または検出され、オーバーライドのためにユーザに提示され得る(図39)。検出は、例えば、セルの場所(第1のアイテムがヘッダであることの検出を実証する図40)、その下にリストされた行と比較したフォントの太さまたは下線などの書式設定の差異、または簡単にシートの第1の行を取り上げることに基づくことができる。デスティネーションシステムは、訪問者により挿入が完了した後で訪問者に自動的にリダイレクトするためのオプションとして他のページのリストを提供することができる(図44)。デスティネーションシステムは、次いで、それらのそれぞれの入力制御の傍のヘッダ行に列に基づくラベルを有する、自動的に生成される入力フォームを訪問者に示し、訪問者がデータを挿入することを可能にし得る(図91)。スプレッドシートのClientListからのセル書式設定は、自動的に生成される入力フォーム上のセルのラベルのhtml書式設定および入力制御に影響を及ぼし得る。各入力フィールドに関するラベルは、“Header Source”により決定されてよく、典型的に、ソース範囲の第1の行、Defined Name、またはユーザにより選択された範囲のいずれかである。
Insertページがより高い複雑さまたはカスタムの要件を有する場合、設計者はまた、例示的な実施形態によれば、スプレッドシート内の第1のClientListソースに加えて、スプレッドシート内の“Template Source”を指定することもできる(図35)。これは依然としてクライアントのリストへの挿入を行うことになるが、入力フォームユーザインターフェースは、Template Sourcesにより定義され得る。Template IndicatorがそのTemplate Sources上のどこで見つかっても、セルの表示は、自動的に生成される入力制御に置き換
えられてよく、入力制御の書式設定は、Template Indicatorセルの書式設定からとられる。
別のページタイプは、例示的な実施形態によれば、指定のレコードソースおよびTemplate Sourcesに基づく“details”ページである。デスティネーションシステムは、テンプレートがどのレコードに対して適用されるべきかを訪問者が選択することを可能にする、テンプレート化されたレポートのレンダリングの結果の上に制御を配置し得る。代替として、Detailsページは、Reportページと組み合わせて用いられ得る。ReportページとDetailsページとの両方は、ソースとしてClientListスプレッドシートを有することになる。ClientListスプレッドシートは、“Go To Details”と呼ばれる追加された列を有してよく、各行は、“=NAVIGATETO(‘DetailsPage’,A3:Z3,Blue,LinkStyle)”などの式を有することになり、これは、クライアントのすべてをリストするメインReportページの表示中に、行3またはクリックされたそれぞれの行によりポピュレートされるDetailsPageに訪問者を連れていくことになる、ハイパーリンクスタイルナビゲーション制御が各行上で見えるべきであることをデスティネーションシステムに示すことになる。別の代替として、Reportページ作成中の構成オプションは、ClientListスプレッドシート内の指定の右にそれらを有するのではなく、生成されるべきナビゲーションリンクを指定するように設計者に促し得る。Detailsページ上の評価されるレコード値のセル書式設定は、Template Indicatorセル書式設定とTemplate Indicatorセルにレコードデータをポピュレートするセルの任意の所与の行の書式設定との組み合わせであってよく、組み合わせ可能な書式設定に対して両方のセルが競合する書式設定を有する(レコード上の色の変更がテンプレート上のより大きいフォントサイズと組み合わされたなどの)場合にどちらの書式設定が優先になるかに関するデスティネーションシステムのデフォルトの挙動および設計者により選択される好みに応じて一方が他方をオーバーライドする。デスティネーションシステムはまた、ほとんどの一般的なフォーマットはテンプレートフォーマットをオーバーライドしないが、いくつかの稀な、したがって、意図的な書式設定の変更はテンプレートフォーマットをオーバーライドすることを許され得ることを保証するべくレコードを分析してよい。
訪問者がデスティネーションシステム上のデスティネーションページ内からセルを編集するために、例示的な実施形態によれば、設計者は、Edit Cellsページ(図38)またはEdit-Recordページ(図41)を作成することができる。ページ作成ウェブページから、タイトルを入力し、ページタイプ“Edit-Cells”または“Edit-Record”を選択することにより、それらは同様に作成され得る。Edit-Cellsページは、訪問者が個々のセルを編集することを可能にするが、訪問者が可視要素(図88)との対話を始めるまでは、Reportページによく似たページを表示する。Edit-Recordページは、訪問者がレコード(図89)をブラウズし、行または列を編集および/または削除することを可能にしてよく、デフォルトのフォーム生成を有するInsertページと類似していてよい(図90)。ページソースは、ページ上に表示されるべきセルの値の範囲であってよく、デフォルトで、どんなセルを編集することができるかを指定する第2の範囲(図42)は、すべてのセルが編集可能であるようにページソースと一致する。範囲は、ワークシート全体、定義名、および/またはカスタム範囲であり得る。デスティネーションシステムは、データを有するすべてのセルおよびデータを有するものの間のセルを表示するべくソース範囲を調べる。両方の編集ページはまた、ユーザが挿入することによりレコードセットを拡張できるようにするべく、空きスペースの付加的な行および/または列を有し得る。定義名またはカスタム範囲は、該
範囲により参照されるセルのみを含むことになる。デスティネーションシステムは、設計者により範囲が指定された後で定義名を作成することによりカスタム範囲オプションを実装し得る。Edit-Recordページタイプは、ページ上で利用可能な編集ボタンを決定し得る、RowまたはColumnの付加的な選択を有する(図41)。
しいセルの値、セルの行および列、データのタイプを記述するセルタイプ、およびデスティネーションシステムページが別のウェブページに埋め込まれるか否かを示すBoolean。ファイルがアップロードされる場合、ファイルキー、ファイルid、およびファイルデータが同様に送信される。サーバが編集要求を処理した後で、セルに表示されるべき新しいテキストを指定するJSONオブジェクトがクライアントに返送される。
Add-OnでCalendarページが作成され得る(図27)が、それらはまた、例示的な実施形態によれば、ウェブサイトを通じて作成することができる。Calendarページを作成するために、3つのデータ:Event Date(必須、日付によりフォーマットされるセル)、Event Time(随意的、時間によりフォーマットされるセル)、およびEvent Title(必須)が用いられ得る。ユーザは、Add
Pageボタンを選択し、次いで、ページタイプとしてCalendarを選択する。パラメータのそれぞれに関するセル範囲をどのようにして入力するかの2つのオプションが利用可能である。定義された名前およびカスタム範囲。Defined Nameは、ユーザが、付属のWorkbookから抽出されるDefined Nameオプションのリストを選ぶことを可能にする。Custom Rangeは、“Use current selection”ボタンを押すことまたはセレクタに手動で入力することのいずれかにより、ユーザが範囲を指定することを可能にする。これらのパラメータが指定された後で、ページを保存することができる。イベントの日付は、唯一必要とされるフィールドであり、タイトルなしのイベントは、デフォルトで“Event”に設定され、時間なしのイベントは、デフォルトで“All Day”に設定され得る。サーバに変更をアップロードした後で、Calendarページビューは、指定のイベントを含むCalendarウィジェットを表示する。3つの指定のパラメータソースが抽出され、Title、Date、およびTimeプロパティからなるイベントオブジェクトを構築するのに用いられる。これらのオブジェクトは、次いで、典型的にはそれらの適切な日付内のタイトルリストとして、Calendarウィジェット上に表示される。設計ページ上のサムネイルは、レンダリングされたCalendarウィジェットを反映するおよびそれと一致する。
Containerページは、別のページの1つまたは複数のインスタンスを含むことができるページである。それらは、ページ作成中にTypeドロップダウンから‘Container’を選択することにより作成される。コンテナページを作成するのに用いることができる、少なくとも3つの異なるモードが存在し得る。UIのボタンを介して選択することができる、Easy、Advanced、およびGraphic Designer(図29)。
asyモードで作成されるコンテナにおける列の数は、或る数、例えば、3に制限される場合もある。
ページを含むことができないことである。2つ目は、コンテナが、該コンテナ自体を、または無限ループを生じることになる別のContainerページを含むことができないことである(コンテナループの例:ページ‘A’はページ‘B’を含むが、ページ‘B’も‘A’を含む)。これらのルールは、保存時にチェックされ、違反する場合、コンテナの作成が防止され得る。
コンテナページは、コンテナの定義、例えば、表示するサブページの列の数および表示するサブページが、コンテナテンプレートシートによって定義され得る付加的なモードを有し得る。コンテナテンプレートシートのセルは、いくつかの態様によれば、単にサブページまたは他の一意の識別子の名前であってもよく、シート内で利用される列の数は、コンテナページ上に表示されるサブページの列の数を表すであろう。これにより、設計者にかなりの柔軟性を持たせることができる。例えば、設計者は、セルA1:A3などの複数の列にわたってセルをマージし、その周囲に境界線を置き、セルコンテンツをテキスト「ヘッダページ」に設定して、ヘッダサブページが境界線を有し、データおよび他のテンプレートがどのように定義されるかと一致する身近な方法で3列にまたがることを示し得る。設計者はまた、どのサブページを訪問者に示すべきかを示すために式を使用し得る。“=IF(Item.Count(A:A)>50、‘Line Graph Page’,‘Bar Chart Page’)”などの式は、カウント内に多くのアイテムがあるときに、折れ線グラフが示されるが、アイテムが少ないときに棒グラフが示されるように、示されるサブページを変更する。“=IF(item.A1<EDATE(NOW(),-1),‘Readonly Page’,‘7Editable Page’)”などの式は、レコードを1ヶ月後まで編集することを可能にし、その後、そのページは、編集制御とは対照的に読み取り専用ビューを提示することができる。
を許可されるべきであることをwebifierに指示することによって、どの特定のセルがレンダリングされるべきかを指定し得、webifierは、メタデータとして、かつ/またはシートとは別個にそのような嗜好を格納し得る。
CSV Importページ(図86)は、例示的な実施形態によれば、訪問者がCSVファイルから一度に複数の行をスプレッドシートに挿入することを可能にする。設計者は、CSV Importページに関するソースとしてワークシート、定義名、またはカスタム範囲を選択することができる(図33)。このソースは、ページ上のどこに新しいデータが入力されることになるかを指定する。これは、インポートされるCSVファイルにおいて可能な列の数を制約するまたはしない場合がある。例えば、$A$1:$C$1の範囲をカバーする定義名ソースは、3つの列を有するCSVファイルのみ可能にすることになり、データは、列A、B、およびCにわたる最高の利用可能な行に挿入されることになる。
タイトルおよびソース範囲で指定され得る別のページタイプは、例示的な実施形態によれば、埋め込み型スプレッドシートページである。このページタイプは、埋め込み型スプレッドシート・インターフェースを訪問者に表示し、スプレッドシートの設計者により指定された部分の値および式を設計者がするのと同じ方法で訪問者が編集することを可能にする。スプレッドシート制御の実装は、包括的である必要はなく、訪問者がスプレッドシート外のデータを参照するどのような能力を有することも必要としない。この実装は、データをスプレッドシート定義フォーマットで受け入れ、訪問者が保存すると、結果的にスプレッドシート定義フォーマットを生成する、多くの市販のスプレッドシートウェブ制御のうちの1つを利用することができ、この場合、セルの式またはセルの値は、スプレッドシート制御に提供される一時的なシートにおよびそこから1つずつ容易にコピーされ得る。
Webifierは、例示的な実施形態によれば、複数の他のページタイプを同様の様態でサポートすることができる。例えば、前述の“report”ページタイプと類似しているが、デスティネーションシステムは、Reportページのhtmlを、訪問者がそのPDFページのURLにアクセスするときにブラウザまたはモバイルアプリケーションによりダウンロードされ開かれるPDFドキュメントへ変換するまたは印刷する付加的なステップを行うためにPDFライブラリへの市販のコンバータまたはプリントを用いてよい。
スプレッドシートが定義されると、webifierは、例示的な実施形態によれば、スプレッドシート定義に基づいてデスティネーションシステムページを生成し得る。スプレッドシート定義がデスティネーションシステム上に持続的に格納される例では、プロセスは、適用可能なソース範囲内に入るセルの定義を抽出し、利用可能にすることで始まる(図2のステップ207)。スプレッドシート定義がxlsxファイルフォーマットで始まる場合、ファイルは、XMLフォーマットの中身を取得するべく解凍され得る。初歩的な文字列パーシングから洗練されたパーシングまでの様々なXMLパーシングオプションが、通常は、XMLパーシングライブラリにおける関数を呼び出すことにより行われ、セルおよびそれらの属性を含む個々のデータセクションのすべてを通して反復するために、並びに、それらをインメモリオブジェクト指向クラスおよびインスタンスなどの代替または中間フォーマットへロードするために便利なアクセスを提供するのに用いられる。代替的に、xlsx、MS-XLSB、SpreadsheetML、ODSフォーマット、および同様のスキーマに適合する市販のスプレッドシートファイルフォーマットパーサが、スプレッドシートのデータを、スプレッドシートデータにおいて典型的に見受けられる属性およびフォーマットに便利に特化されたオブジェクト指向クラスで明らかにするのに用いられ得る。
ステップ207および/または209(図2)中に、データは、中間フォーマットに変換されてよく、これは、例示的な実施形態によれば、関連するデータ属性を、スプレッドシートクラスではなくCSSまたはHTMLクラスにより近く似ているクラスでより便利にアクセス可能にし得る。例えば、クラス上のプロパティ名は、CSSのプロパティ名と一致してよく、または“ObtainCSSDefinition()”などのクラスに対するいくつかの方法が存在し得る。しかしながら、中間フォーマットの便利さは必要とされず、代替的に、webifierは、CSSおよびHTMLのデスティネーションページの出力フォーマットに従ってデータを格納してよい、または、データをオリジナルのスプレッドシートフォーマットで格納し、後でストリームを中間ストレージなしに出力フォームへまっすぐに向けてよい。例えば、列の幅を処理するために、XMLスニペット“<col min=“1” max=“2” width=“11.8”>”の“width”属性の値を読み出し、CSSによりサポートされるユニットに変換し、結果的に生じる列クラスの“csswidth”プロパティを格納する、またはこれをCSS出力ス
トリーミング機能の一部として“width:100px;”としてストリーム出力することもできる。
訪問者に送信されることになるCSSテキスト定義に関するストリームへのオブジェクトのプロパティのシリアライズの一部として、デスティネーションシステムは、例示的な実施形態によれば、どんな種類のページタイプおよびどんなタイプの訪問者デバイス特徴が所与のターゲットページに適用可能であるかなどのファクタを考慮に入れ得る。例えば、ページが“report”タイプのものである場合、webifierは、“<td>Cell Text</td>”のようなHTML TDセルとしてのボーダーを有するセルおよび“td{border:1px solid black; }”などのいくつかの関連するCSSを出力し得る。しかしながら、ページが“edit details”タイプのものであり、且つ、セルが編集することができるセルとして指定される範囲内に入る場合、webifierは、代わりに、所望の入力制御のスタイルに応じて“<td><input type=text value=”Cell Text”/></td>”として同じセルおよび異なるCSSを出力し得る。
往々にして、スプレッドシートツールは、データ検証能力を含む。例えば、データ検証ルールは、スプレッドシートツールで指定することができ、その場合、セルは、特に、整数のみ可能にする、10進数のみ可能にする、指定の最小範囲および最大範囲内の数のみ可能にする、おそらく最小範囲および最大範囲内の日付または時間のみ可能にする、可能な文字の最大数を制限する、または必要な文字の最小数を制限するべきである。データ検証はまた、セルが、リストで指定される値のうちの1つを含むことのみ可能にするように設定することができる。リストは、値のシンプルテキストリストとしてデータ検証定義中に提供することができ、または、スプレッドシート上のセルの範囲への参照を指定することができ、その場合、ツールは、そこから容認できる値のリストを得ることになり、該セルに関するスプレッドシートツール内にドロップダウン制御を生じさせることができる。データ検証はまた、結果的にtrueを返す典型的なスプレッドシート式を生じることになる値のみを可能にするように設定することができる。例えば、セルB1に関して、式は、“=OR(B1>=0,AND(A1=0,A2<40))”を指定することもでき、この場合、B1は、正の数とすることができ、またはセルA1がゼロであり、且つA2が
小さい数である場合に、負とすることができる。いくつかのツールは、ブランク値が検証をパスすることを可能にするべく例外を指定することを可能にする。例示的な実施形態によれば、デスティネーションシステムは、スプレッドシートおよびスプレッドシートセル定義から設計者が指定した上記のデータ検証タイプおよびオプションのすべてを読み出すことができる。データ検証は、セル定義XML上とすることもでき、またはデータ検証ルールは、ルールが適用されるセルのリストと共に、スプレッドシート定義におけるグループとしてどこか別の場所で定義することもできる。デスティネーションシステムは、スプレッドシート定義から該情報を抽出および処理してよい。スプレッドシート内で適用されたデータ検証ルールを有するセルに対応するデスティネーションシステムからの値の挿入または編集などの入力中に、デスティネーションシステムは、訪問者の入力値をこれらの検証ルールと比較して評価することになる。評価は、サーバ上で行うこともでき、または例えば要求がサーバへ送信される必要なしにユーザの入力を評価することになるクライアント側JavaScriptにルールを渡すことにより行うこともできる。データ検証に失敗する場合、訪問者に値を訂正する機会を与えるべくラベルまたはポップアップ警告が示されてよい。データ検証ルールが、そこから容認できる値のリストを得るためのセル参照に関係していた場合、またはデータ検証ルールが、true評価を必要とする式に関係していた場合、システムは、式を評価するのに必要とされるまたはシステムが容認できる値のリストを知るのに必要とされる他のセルの値をデリファレンスしてよく、これは次に、訪問ユーザの入力を可能または不可能にすることになる。スプレッドシート定義が、日付に基づくルールを指定する場合、デスティネーションシステムは、ユーザがそこから日付を選ぶべくポップアップのカレンダー制御を有するように、挿入または編集フォーム上に出力される制御を修正してよく、随意的に、無効な値が警告付きでタイプされるがサーバへサブミットされないようにするのではなく、無効な値が最初から指定されるのを防ぐために、テキストボックス制御自体にタイピングすることは不可能にされる。
Webifierでは、あらゆる種類のシートは、長期にわたってすべてのユーザ間で一貫性がないシートデータの同時バージョンである一過性データを含んでよい。例えば、配信されている単一のデスティネーションページに固有のデータ、訪問者ブラウザセッションごとのデータ、1日あたりなどの周期的なデータ、訪問者あたりであるがブラウザセ
ッションにわたって持続的であるデータ、役割またはユーザグループごとであるが永続的であるデータ、および/または1日あたりの訪問者あたりなどの上記の組み合わせを含む、いくつかのタイプの一過性データが存在する。デスティネーションシステムは、一過性データがブラウザセッションのグループに適用されるように、訪問者ブラウザセッションの開始または終了時に一過性データを継続して使用するか、またはリセットするように訪問者に要求し得る。すべての種類の一過性データについて、データは、デスティネーションシステム内に格納され、アクセスがログされ、視聴および修正のために設計者ユーザに利用可能であり、非一過性データと同様に利用するためにwebifierシステムの他のコンポーネントに利用可能であり得る。
て変化し得るが、ページへの同時訪問者の多くは、それぞれ自分のナビゲーション国の選択に対応する値を確認し、他のユーザのナビゲーション選択または以前のブラウザセッションにおける自身の選択の影響を受けないであろう。しかしながら、この例では、デスティネーションシステムは、一過性ナビゲーション選択を依然として格納し得る。
cellA1列のような列の各値ごとに変化し得る。次いで、設計者は、“Highest Label”と従来のスプレッドシート式“=MAX(AutoGenTransientSheet! B3:B1000)”は、非一過性の行を除外し、すべてのユーザがセルRecordSheet!A1に設定した最大値を表示する関連するレポートページを作成することができる。設計者は次いで、AutoGenTransientSheet全体のデータソースを有する編集セルページを作成してもよく、デスティネーションページへの訪問者が他のユーザの一過性値を修正することを可能にする。
ないとき、デスティネーションシステムは、訪問者ブラウザセッションなどの現在の要求コンテキストのスコープと一致する狭いスコープを有する一過性バージョンを自動的に使用しようとし得、任意の狭いスコープが存在しないときに、任意の適用可能な一過性バージョンが非一過性バージョンに戻ることができるまで、訪問者などの広いスコープを有する一過性バージョンを使用しようとし得る。
多くの訪問者が、デスティネーションシステムにログインし、読出し専用ページを同時に要求することもできる。編集に関係する要求に関して、サーバは、例示的な実施形態によれば、入ってくる要求またはレコードを修正する要求のコアコードのすべてをキューにシリアライズしてよく、これは、今日の処理能力を考えると事実上同時であるように見えるであろう。多くの異なるページタイプに適用可能な、デスティネーションシステムは、スプレッドシート定義から生じるセル参照および式を、ユーザに表示されるまたはスプレッドシート定義におけるまたはデスティネーションシステムの他の領域内のさらに他の式に再帰的に用いられることになる、シンプルテキストおよび数値へ分解し得る。式の分解は、多くの方法で完了され得る。スプレッドシートツールと同じコア処理エンジンまたはライブラリが再利用されてよく、またはカスタムのパーシングおよび式処理エンジンがデスティネーションシステムに埋め込まれるように構築されてよい。いずれにしても、エンジンは、行および列のインデックス値に基づいてセル参照を分解する1つまたは複数のコールバックを有してよく、または、セル定義を格納するデータベースにスプレッドシート定義を渡すまたはこれにアクセスすることもできる。パスインされるスプレッドシート定義は、パスインされたオリジナルのスプレッドシート定義と同じではない、簡易化されたまたは他の方法で修正された、再生成された定義であってよく、またはオリジナルのスプレッドシート定義がパスインされてよい。編集に何らかの衝突があるケースでは、システムは、時間(例えば、最後の人が勝つ(last man wins))または任意の他の所望のヒューリスティックスに基づいて受け入れられた編集を選択または指定し得る。
Webifierは、例示的な実施形態によれば、ワークフローのいくつかのフォームが、Reportページタイプおよび他のページタイプのバリエーションで定義されることを可能にし得る。行レコードシート上で、行ごとの、したがって、レコードごとの訪問者パーミッションに影響を及ぼすことを意図した列を設計者が追加することもでき、その場合、特定の列のセルの式の結果により、デスティネーションサーバがその行を出力結果に含むまたは含まないことになる。例えば、列Aが従業員の名前を含み、列Bがいくつかの時間を含む従業員タイムシート・スプレッドシートと、該シートのソース領域を有するReportページタイプを想像してみる。追加の列Cは、“=IsLoggedInUser(A1)”に似たレコードを表す各行に関する式を有してよく、この場合、A1は、第2の行に関してA2に、以下同様に変化することになる。これは設計者に値を示すべく設計時間中に分解することができないが、デスティネーションシステムは、Reportページをリストするタイムシートを訪問者が訪問するときに式の列を評価することになる。反復中に、デスティネーションシステムは、その行の列Aで指定される従業員が訪問者ではなかった場合に、訪問者に関する行のレンダリングをスキップすることになる。行は、列Aにおける訪問者と一致した場合にレンダリングされ続けることになる。最終結果は、従業員が、該従業員に関係する時間レコードの行のみを示すことになるスプレッドシート定義に基づいて、タイムシートウェブページを訪問することができたことである(図20)。同様に、シートがスーパーバイザを指定する列を有していた場合、スーパーバイザのタイムシート概要ページは、該スーパーバイザの権限下の時間レコードのみをリストし得る。
を非表示にするだけでなく、他の行の編集を可能にしながらユーザがいくつかの行を編集することを防ぐために入力制御が提供されることも防ぐ。これらのコンポーネントを一緒にすることの望外の効果は、タイムシートページ上で自分のタイムシートだけを見る従業員などのユーザがワークフローを定義できるようになり、“ready to submit”列を1つまたは複数のレコードに関してtrueに変更することができ、スーパーバイザは“ready to submit”列に基づいて閲覧する行を限定する式を有するページ上に現れたこれらのレコードを見ることができ、スーパーバイザは自分が監督する従業員のみに関する“approved”値を変更することができ、最終的にマネージャは承認されたレコードおよび承認された時間の総計のみを見ることができることである。手短に言えば、本明細書で説明される態様は、これまでは経験を積んだソフトウェア開発者の支援を必要としていた、カスタムの複雑なワークフローの作成を可能にする。
訪問者の便宜のために、例示的な実施形態によれば、値のテキスト編集をボタン制御へ変更するためのシグナルとしてデスティネーションシステムが見るタグを含むスプレッドシートツールのコメント特徴を用いて、メタデータが、セル、例えば、セルコメント上で指定され得る。例えば、設計者が各データレコード上の“approved”値を望んだ場合、文字列“true”をタイプするべくテキストボックスを訪問者に提示するのではなく、セルの値をfalseからtrueに変更することによりレコードの承認を示すべく訪問者がボタンをクリックできることが設計者に好まれる場合があり、その場合、訪問者は“false”に“true”を戻し入れるように変更し得る。これは、結果的により使いやすいシステムをもたらすとともに、値への変更が一方向であるケースの一助となる(例えば、falseからtrueになっても、設計者は、レコードが決してfalseに戻ることが有効であるとは感じない)。
入力を防ぐことは、設計者がソースはレコードシートであると指定したページに関する制御を無効にすることまたは非表示にすること、若しくはサーバが多少なりとも制御を訪問者に送信しないようにすることを含むことができる。セキュリティのために、サーバはまた、例示的な実施形態によれば、訪問者は通常のブラウザではなく悪意のあるエンドポイントである可能性があるため、HTTP POST要求を用いて投稿されるサブミットされた入力が同じ論理に基づいて許されるかどうか、制御がユーザに提示されたかどうかを確認し得る。様々な行レコードをポピュレートされることを意図された他のテンプレートスプレッドシートを利用する他のデスティネーションページはまた、同じ論理を用いて許容を評価する。例えば、インボイス詳細テンプレートのTemplate Sourceを有するインボイス詳細レポートページが、デスティネーションシステムの訪問者によりアクセスされており、且つ、インボイスレコードリスティングシート上の行2上にインボイス205をポピュレートされている場合、デスティネーションシステムは、行2が行2へのアクセスを制約する式を有するかどうかを指定する列に関するインボイスレコード
シートをチェックすることができる。制約する式を有する場合、デスティネーションシステムはまた、インボイス205に関するインボイス詳細レポートページへのアクセスを制約することになる。ネストされるテンプレートの場合、または単一のテンプレートに複数のソースシートが用いられる場合、および他のこのような複雑なシナリオでは、デスティネーションページの一部はポピュレートおよびレンダリングされ、一部はされないが、カスケーディングの基礎をなす方法は残る。
レコードごとの式を有する列を追加することの代替は、例示的な実施形態によれば、シート上のまたはシートの外部の指定されるまたは参照される場所に入力され、デスティネーションシステム内に格納される、別個の単一式を有することである。この代替では、デスティネーションシステムは、各行を通して反復し、反復している現在の行またはレコードに式を適用することになる。webifierの他の領域は、代替的な式の同じ集中化を利用し得る。
representing the record currently in question(当該レコードを表す行に関する列Aの値)”に等しいと理解し得る。言い換えれば、これは、式を、上記の列Cを有することに等しいと理解し得る。別の代替的な例として、“=IsLoggedInUser(A)”式は、行レコードと同じシート上のどこかの単一セル内に、おそらくセル“Z1”における行レコード情報のはるかに右に配置され、フィールドは、どんな単一セルが行ごとのパーミッションに関する式を表すかを指定するページ定義ステップ中に存在し、このような例では“Z1”に設定され得る。
往々にして、単一のレコードシートは、異なるパーミッションおよび異なる意図された訪問者を有する多くのデスティネーションシステムページの基礎である。このようなケースでは、例示的な実施形態によれば、それぞれのデスティネーションページのパーミッションに影響を及ぼすべく異なる式を含むためにいくつかの列を用いることもできる。代替として、デスティネーションシステムは、スプレッドシート定義にOverlay Sheetを追加してよい。Overlay Sheetは、最初にすべて同じ値を有する行レコードシートの複製であり得る。これは、行レコードシートに基づくことを意図されたおよびページに固有の修正を有することを意図されたシートとして、シートのスプレッドシート定義上のメタデータと共に、デスティネーションシステムによりOverlay Sheetとしてフラグを立てられ得る。設計者は、次いで、Overlay Sheetに列Cを追加してよく、デスティネーションシステムは、上記とほぼ同じように列Cを用いてよいが、代わりに行レコードシートに追加されたかのように式を評価し、これは、Overlay Sheetが作成されてからリストが変更された場合に行レコードの最新のリストに対してそれが作用することを可能にする。異なるデスティネーションページに関する異なるOverlay Sheetsは、異なる列C式を有し得る。Overlay Sheetsは、ベースの内容を同期して保つために、行レコードシートが変更されたときにはいつでも更新され得るが、意図された新しい列Cだけは例示的な違いとして
持続する。
デスティネーションシステムが、ページ作成中に列Cが行ベースのパーミッションを指定することを示すフィールドを有するのではなく、代替は、例示的な実施形態によれば、これを暗示するスプレッドシート定義を有することである。スプレッドシートは、伝統的な“spreadsheet tables”を有してよく、これは通常、セルの領域を備え、スプレッドシートツールを色付けすることができ、ヘッダロー上のフィルタオプションおよびソートオプション、および伝統的なスプレッドシートツール内で閲覧されるときのシート内の行の表示を管理するための他の特徴を有することができる(図74)。webifierは、ページのために用いられるソース行レコードシートのスプレッドシート定義におけるまたはページのために用いられるOverlay Sheetにおける伝統的なスプレッドシートテーブルの存在をチェックすることができ、テーブルが存在する場合、webifierは、フィルタリング、ソーティング、および他の方法のためにテーブルの持続状態を見てよい。設計者が列Aによりテーブルのセルをソートした場合、デスティネーションシステムは、同様に列Aにより出力をソートすることになる。列Cの式に基づいて行ベースのフィルタリングパーミッションを選ぶ、前の例に関して、設計者は、テーブルを列“C=true”上でフィルタするように設定することもでき、デスティネーションシステムは、同じ論理で結果出力をフィルタすることになる。このようにして、ページの作成者が、行を見るのにtrue評価を必要とする行ベースのパーミッションを列Cが有することを示すことは必要とされない。
デスティネーションシステムが、デスティネーションシステムの訪問者に読出し専用および/または入力可能フォームおよび内容を提供するべく設計者のスプレッドシート定義
を既に利用した後で、およびデスティネーションシステムの訪問者がレコードをもしかすると修正または入力した後で、デスティネーションシステムは、例示的な実施形態によれば、すべてのデータおよびテンプレートの更新された、統一された、またはマルチパートの表現を、スプレッドシートツールに十分に適合するスプレッドシートフォーマットで、設計者に提供することができる。便宜上、これは、ステップ215で行われ得る場合の、抽出と呼ぶことができる(図2)。抽出は、ダウンロードされるファイルとして、またはデスティネーションシステムから情報を受信し、スプレッドシートツール内のシートを更新するデスティネーションシステムのAdd-Onまたはプラグイン(図54の“Download data”ボタン)を用いてスプレッドシートツールを更新することによって提供することができる。ほとんどのケースにおいて、設計者は、デスティネーションシステムからのさらなる関与が全くなしに、更新されたレコードを有するだけでなく、レコードシートに基づいて実際のデータを表示するレポートも有するスプレッドシートを受信するであろう。
る。Add-Onは、すべてユーザの最小の関与でまたは関与なしに、更新のリアルタイムチェックを有するが、任意の新しいスプレッドシート定義をローカルファイルとしてハードドライブ上にダウンロードおよび保存し、次いで、これを開くようにスプレッドシートツールをトリガする、ハイブリッド手法を取り得る。
Add-Onを介してまたは他の方法でファイルとしてまたはスプレッドシートツールへ抽出されるのいずれであるかに関係なく、例示的な実施形態によれば、設計者は、このとき、デスティネーションシステムを用いる前に行ったのと同じようにテンプレートシートおよび/またはレコードシートにさらなる修正を行うことができる。実際には、設計者は、デスティネーションシステムに空またはほぼ空のスプレッドシート定義を入れ、次いで、設計時間に関連する任意のデスティネーションシステム特徴を活用するべく、抽出された後にのみスプレッドシートの構築を始めることを選択し得る。単純な例として、特定の新しいweb-appを示す特定の新しいスプレッドシートは、デスティネーションシステムがこの新しいweb-appをappのリストに表示することに起因して、そのユーザにより設計されていることを他の設計者に協調のために気付かせる。
くユーザに競合情報を提示する。
“A6:A11”に下方シフトすることをデスティネーションシステムに通知する。
Add-Onを通じて行われたときに、webifierシステムは、例示的な実施形態によれば、スプレッドシートから(例えば、後述のCOM Interopライブラリを介して)またはデスティネーションシステムサーバから名前付き範囲を取得し、その名前を、JavaScriptを用いてAdd-Onのウェブベースのユーザインターフェースに渡し得る。webifierは、デスティネーションページを作成または編集するときに、または、デスティネーションシステムがスプレッドシートセルへの参照を必要とするおよび処理されるべき訪問者要求のために参照がデスティネーションシステムにアクセス可能である必要があるあらゆる他のフィールドまたは状況で、データソースに関する現在選択されたセルを取り込むために新しい名前付き範囲を作成し得る。これらの範囲の名前は、“WebifierCustomRange”であり、例えば0~2,147,483,647のランダムに生成される数が付属し得る。その名前をもつ範囲が既に存在する場合、新しい乱数は、作成された名前が既存の範囲に付いていないようになるまで生成され得る。代替的に、インクリメント数が用いられ得る。選択されたセルに関するカスタム範囲が既に存在する場合、システムは、別の名前を作成するのではなく既存の名前を用いることを選んでよい。行の挿入または列の挿入などのスプレッドシートツールにおいて実行される動作は、通常のスプレッドシートツールの使用のように名前付き範囲を拡大する。レコードが、そのソースとして名前付き範囲を有するInsertまたはCSV Importページを介して挿入される場合、これは、該範囲を、挿入されたレコードを含むように拡大することになる。任意のwebifierウェブページにより参照される名前付き範囲がスプレッドシート定義から削除される場合、シートがアップロードされるときに、システムは、無効なソースを有する影響されたページをマークすることになり、それらは、ソースが編集されるかまたは削除された名前付き範囲がリストアされるまで、アクセスできないであろう。名前付き範囲は、Insert、Edit-Cells、Edit-Record、CSV Import、Report、Webpage、Cal
endar、およびDetails Reportページの境界を定義するのに用いられ得る。名前付き範囲はまた、Insertページ、Edit-Cellsページ、およびEdit-Recordページに関するヘッダ範囲を定義するため、およびEdit-CellsページおよびEdit-Recordページに関する編集可能な範囲を設定するために用いられ得る(図81)。Edit-Recordページを用いると、名前付き範囲は、その範囲内のすべてのセルが削除される場合に自動的に削除され得る。
トラックするセルのボリュームが非常に高い場合、名前付き範囲は、例示的な実施形態によれば、デスティネーションシステムにより生成され、抽出されたスプレッドシート定義のすべてのセルに挿入されるユニークセルIDを含む付加的な属性を有することと組み合わせる、またはそれに完全に置き換えることができる。多くのスプレッドシートツールは、スプレッドシートツールが属性の目的の理解を有していないにもかかわらず、スプレッドシートツールにおいてセルが修正または移動またはコピーされていても、この属性をメタデータとして定位置に保つことになる。これは、名前付き範囲の同じ利点の多くを与えるが、スプレッドシートツールのユーザインターフェースにおいて設計者に可視とはなりそうにない。デスティネーションシステムは、次いで、接続解除されている状態でユーザがどんな変更を行うかの知識を取得するべく他のセル属性とほぼ同じようにユニークIDを抽出する。その知識は、次いで、これらのセルへのデスティネーションシステム上の参照を更新するのに用いることができる、または代替的に、これらのユニークセルIDは、あるケースでは、伝統的な行および列のインデックス付けを用いるのではなくセルを指すのにデスティネーションシステムが用いる方法として十分であり得る。範囲はさらに、範囲の左上隅および右下隅を表すUID:UIDとして指定することもできる。
“Configuration Sheets”と呼ばれる名前付き範囲への代替の手法はまた、例示的な実施形態によれば、名前付き範囲の位置に代入することもできる。この手法は、スプレッドシートツールが非表示にされるシートをサポートする場合に潜在的に非表示にされる“DestinationSystemRanges”という名前の付加的なシートを含んでよく、該シートは、名前および範囲の2つの列を有する。デスティネーションシステムは、次いで、アップロード中にまたは各訪問者の要求時に該シートを通して反復し、第1の列の値により、デスティネーションシステムが分解しようとしている範囲を見つけ出すことになる。例えば、“Page1_SourceRange”が、名前のうちの1つであり得る。デスティネーションシステムは、次いで、第2の列のセル
の値または式を取得し、これを名前付き範囲の定義とほぼ同じように用い得る。この手法の利点は、値が実際に伝統的なスプレッドシート式であり得ることであり、したがって、範囲の定義でさえも、スプレッドシート定義の他の要素により影響を受けることがある。これは、望外な量のパワーおよび融通性を与える。例えば、インボイスの合計が>$5000である場合に、詳細ページは、そのページソース構成において、訪問者に示すことが望ましい、しかし該インボイスのみに関する付加的な細字部分をおそらく有する追加の5つの行を含むべきであるという式を指定することもできる。同時に、スプレッドシートツールは、範囲を名前付き範囲とほぼ同じように自動的に同期して保つことになる。これは、特に、最小の付加的な努力またはトレーニングで若しくはそれらなしに、カスタムのレポートの構成を設計者が効果的に修正することを可能にする。
ファイルは、例示的な実施形態によれば、WEBIFIERINSERTFILE関数を用いてデスティネーションシステムにアップロードされ得る(図7)。InsertページまたはEdit-Recordページに関するフォームを構築している間にWEBIFIERINSERTFILE列を含むフィールドに出会うときに、該フィールドに関するFile Upload制御が提示され得る(図62)。同様に、Edit-Cellsページ上のWEBIFIERINSERTFILE関数を含むセルを編集するときに、設計者は、式を編集するまたは新しいファイルをアップロードする選択肢を有し得る。Add-Onを有するスプレッドシートツールにおいてWEBIFIERINSERTFILEに出会うときに、これは、WEBIFIERFILEATTRIBUTES関数を用
いてファイルについての情報を取得するのに用いることができるキーを表示し得る(図64)。
する文字列キーであり、随意的であり得る(図示していない)第2のパラメータは、その属性を得るべくキーの下に格納されるインデックスであり、同じく随意的である最後のパラメータは、取得されるべき属性の名前または数である。ファイルの名前に関する“Name”または0、KBにおけるファイルのサイズに関する“Size”または1、ファイルがアップロードされた日付に関する“DateUploaded”または2、およびウェブサイト上のファイルを閲覧するためのURLに関する“Link”または3。インデックスが指定されないまたはインデックスがファイルの量よりも大きい場合、関数は、最新のアップロードされたファイルの属性を得てよい。属性が指定されない場合、関数は、デフォルトで、ファイルの名前を示すことに設定され得る。
署名は、イメージをアップロードする訪問者のために前述のファイルに基づく外部補足データを用いるのと概ね同じ方法論を用いてデスティネーションシステムにアップロードされ得る。しかしながら、この署名が外部データの形態であるケースでは、ファイルアップロードダイアログおよび制御は、ユーザが署名を入力することを可能にする制御と置き換えられ得る。例えば、レコードシートは、“=WEBIFIERINSERTSIGNATURE(A2,‘thumbnail’)”に似ているすべての行レコード上の式をもつ列を有してよく、この場合、列“A”は、従業員の名前などの一意識別子として役立つことができるデータを有し、A2における“2”は、適切な行に変化し、“presence”は、セルが、署名が利用可能な場合に署名のサムネイル、または署名がまだ利用可能でない場合にテキスト“n/a”を示すことを示す。設計時間中に、Add-Onは、それらをセル内に表示するために各レコードに関するこのようなサムネイルをフェッチし得る。ソースがレコードシート全体に設定されるReportページの訪問者に関して、署名サムネイルは、デスティネーションページ上に表示されるすべてのレコード行の傍に現れ得る。サムネイルは、署名が取り込まれた日付および時間などのメタデータと一緒に取り込んだ署名の大きくポップアップするビューを開くべくクリック可能であり得る。InsertまたはEditデスティネーションページ上で、大きいポップアップビューはまた、大きいキャンバス領域を有してよく、その場合、ユーザによるマウス、デジタルタブレット上のインクレスペン、またはタッチスクリーン上の指の動きが、キャンバス領域にその動きをペンとして取り扱わせ、対応するラインをキャンバス上に引かせることになる。それを行うおよびフォームのサブミッション時にサーバにアップロードされることになるイメージデータと共にhtml入力フォームを提供するのに通例JavaScriptコードを用いる、このようなキャンバスによるイメージファイルへの署名などの動きを取り込むための市販のモジュールが存在する。この例を続けると、デスティネーションシステムは、レポートページ上のレコードに関するその後の署名データの閲覧要求時に取得されるように、署名を表すイメージファイルをデータベースに格納し得る。視覚署名の代替として、デジタル署名を表すデータが、PGP signed署名の多数の第三者型発行者のうちの1つからクライアント側のJavaScriptにより取得されてよく、このようなデジタル署名の手書きのようなフォントを用いるテキスト要約またはトークン人工署名が、署名イメージの位置に表示されてよい。訪問者は、第三者型発行者がデジタル署名を発行するために、このようなハードウェアのための市販のインテグレーションポイントを用いて、ユーザ名とパスワードのペアまたはモバイルデバイスの親指スキャナ上の親指の指紋などの、認証情報の入力を必要とされ得る。
チャットオブジェクト特徴は、例示的な実施形態によれば、チャットディスカッション
のストリームがスプレッドシートの1つまたは複数のセルに埋め込まれるまたは関連付けられることを可能にする。チャットオブジェクトは、他の訪問者が閲覧することができるセルに訪問者がメッセージを追加することおよび該セル上に他者または自分により残されたメッセージを閲覧することを可能にする(図58)。チャットオブジェクトは、メッセージオブジェクトのリストを表し、各メッセージオブジェクトは、典型的に、少なくとも3つの部分:メッセージテキスト、メッセージをサブミットした時を示すタイムスタンプ、およびメッセージをサブミットしたユーザのユーザ名からなる。各チャットオブジェクトはまた、一意識別子、すなわち、他のチャットオブジェクトとは別個の識別子を有し得る(例えば、図59の“6ea6cc…”。識別子は、ユーザに割り当てられたものまたはシステムに割り当てられたものであり得る。チャットオブジェクトの識別子は、チャットオブジェクトを指すためおよびこれを他のチャットオブジェクトから区別するためにwebifierにより用いられ得る。
。
は、該セルに関する式を設定するのにパーミッションを有する必要がある。これは、可能なwebifier API呼び出しを通じて、またはwebifier Add-Onがインストールされたスプレッドシートツールを通じて、を含む種々の方法で行うことができる。
以下に、1つの例示的なユースケースのシナリオでの、デスティネーションシステムに対する訪問者入力のプロセスおよび影響を説明する。webifierシステムにより生成されたInsertページフォームが訪問者によりサブミットされるときに、デスティネーションシステムは、最初に、ページがパブリックであることまたはそれを使用するのに適切なパーミッションがユーザに与えられていることを確認し得る。ユーザが許可される場合、デスティネーションシステムは、ページを含むAppに関連するスプレッドシート定義を取得し、挿入プロセスを開始することになる。ユーザがInsertページの使用を許可されない場合、それらのサブミッションが却下され、システムがユーザに通知し得る。
られ得る。Webifier式を含む任意の行または列が範囲内に存在する場合、それらは、それらがOverlay Sheetにより非表示にされている場合であっても、適切な式をオートフィルされ得る。
本明細書で説明されるように、同じレコードのために、および同様のまたは同じ目的のために、同時に、複数のテンプレートおよび複数のページが存在することができる。目的は、読出し専用と訪問者入力ページの両方を含む任意の目的またはページタイプとすることができる。デスティネーションシステムは、例示的な実施形態によれば、どのテンプレートを表示するかの決定を助けるために、ブラウザまたはモバイルクライアントからの情報を使用し得る。例えば、情報は、画面サイズ、画面解像度、OSバージョン、ブラウザのブランドおよびバージョン、テンプレートのどの組が好ましいかについての訪問者からの手動で指定される好み、および主としてマウス、キーボード、またはタッチスクリーンデバイスのいずれであるかなどのあらゆる数のデバイスの属性または能力を含み得る。web appの場合には、この情報の多くは、http“User Agent”ヘッダから、または、ウェブサーバによりセッション情報として一時的に格納されるこの情報をデスティネーションサーバにインバンドまたはアウトオブバンドで伝送するブラウザ上で実行するJavaScriptを有することにより得ることができる。モバイルappの場合には、appは、デスティネーションシステムへの最初のログイン認証時にこの情報を収集および送信するように設計することができる。
本明細書で説明される場合のシートを用いる複雑なソフトウェアの構築は、他の手段よ
りも非技術系の人々にとってはるかに簡単である。それでもなお、webifierシステムおよび/またはAdd-On(プラグイン)は、例示的な実施形態によれば、アチーブメントと考えることができる設計者側の種々のアクションまたはアクションのグループを待ち得る。これらのアクションが種々の基準を満たす場合、それらがアチーブメントに至ったことを示すべく設計者に視覚ポップアップが手短に表示され得る(図15)。ポップアップは、“Your web-app is now ready to receive new records”または“You are done making your first web-app report”などの設計者が今作成したものの値をリレーし得る。基準は、設計者がこれらのアクションをとった最初の2回のうちの1回だけ、過去数か月の間に設計者がそのようなアクションを完了していない、訪問者が設計者のアクションに関係したデスティネーションページも訪問した、そのようなステップが時間を測られた前回よりも短い時間でユーザがいくつかのアクションを完了した、またはユーザが何かを達成するための異なるワークフローまたは異なる方法を試したなどの複数の基準を含むことができる。アクションは、デスティネーションシステムのまたはAdd-Onのユーザインターフェースとの対話、または設計者が作成するデスティネーションページに関連する訪問者の対話を含み得るだけでなく、設計者のスプレッドシートの分析にも基づき得る。例えば、ゲーミフィケーションシステムは、設計者が伝統的なスプレッドシートテーブルを作成したかどうか、設計者がテンプレートシート上の伝統的な条件付き書式設定を用いたかどうか、またはさらには、設計者が“=SUM(A1:A10)”のような式における基本集計関数を用いたかどうかを見てよい。
例示的な実施形態によれば、デスティネーションシステムにおいて、通知ルールはファシリティを提供し、それにより、或るイベントの発生は、指定のアクションをトリガすることができる(図83)。レギュラーユーザは、自分用の通知を設定することができる。管理者または設計者ユーザは、自分と自分の管理ドメイン内のユーザ用の通知を設定することができる。複数のイベントを取り扱うおよび/または複数のアクションを行うために、ユーザは、複数の通知を設定し得る。各通知ルールのセットアップは、通知をトリガするべきイベントについての詳細および通知がトリガされるときに行われるべきアクションについての詳細をユーザが指定することを必要とする(図84)。通知ルールは、また有効にする必要があるときにまた設定を入力する必要がないようにすべてのその他の詳細を保った状態で無効にすることができる。
バに伝えられるまたは持続されるまではできないかもしれない。イベントの例は、データがページに挿入されるとき、ページ上のデータが編集されるとき、ページの構成が変更されるとき、およびappの構成が変更されるときを含む。明確にするために、イベントの例は、訪問者が高レベルのイベントをトリガした(Insertページのサブミットボタンを押した)、設計者による高レベルのイベント(新しいページを作成した)、セルのイベントをトリガした(セルを変更した)、領域のイベントをトリガした(セルのグループ内の少なくとも1つのセルを変更した)、シートのイベントをトリガした、のカテゴリ内とすることができ、直接的(セルの式を変更した)または間接的(セルの式自体は変更されていないにもかかわらずセルの式の結果が変更された)の両方とすることができる。このようなアクションが起こるとき、アクションは、該アクションに対応するドメインイベントを生じ得る。
通知イベントに対する(例えば、とりわけ上記のボタンおよび通知に関する)潜在的なアクションは、(レコードシート、テンプレートシート、仮想シート、一過性シート、構成シート、およびwebifier内のすべての他の種類のシートなどの)任意の種類のシート上のセル上の値を挿入し、削除し、かつ設定する手順アクションを含み得る。これらの手順アクションの具体的な内容は、“=IF(A1=100,SetValues(A1:A2,B1:B2,false)”のように他の従来の式関数内にネストされた“=SetValues(ソース、デスティネーション、パラメータ)」のように従来の宣言スプレッドシート式に類似する構文、および/または“dest=source”のように手順プログラミングに共通する構文で宣言され得る。ソースおよび/またはデスティネーションは、シート全体、名前付き範囲を含むシート範囲、他のシートデータを参照する式、またはその挿入ページ制御によって影響を受けるであろう基礎をなすセルを参照するのと同じ効果を有するであろう挿入ページ上の制御への参照の組み合わせであってもよい。ソースの場合は、1、“hello”、または1+1などの静的値であってもよい。デスティネーションが範囲である間、ソースが静的値である場合、静的値は、デスティネーション範囲内の各セルに対して設定され得る。値を挿入する場合、手順関数SetValuesへのパラメータは、既存の値を上書きするか、既存の値を挿入してシフトダウンするか、左に挿入してシフトするかなどを指定し得る。手順関数DeleteValuesは、削除してシフトアップするか、削除して左にシフトするか、空のままにするかなどを指定し得る。パラメータはまた、ソースセル内の任意の式が値に分解されるべきであるか、値としてコピーと呼ばれてよいか、またはデスティネーションコピーが、式によってコピーと呼ばれてよいソースセルの式定義を保持するべきであるかどうかを指定してもよい。
Webifierのユーザは、スプレッドシート式を使用していくつかのデータが宣言されるが、最初に作成された後にデータが変更されない、または将来のある時点でフリーズされるアプリを構築することを望み得るが、これは総称して不変性と呼ばれ得る。
alueParams.Overwrite)”または簡略化された同等の“FreezeValues(InvRecords)”でスクリプトを実行する挿入ページ実行によってトリガされる通知イベント設定を有し得る。結果として、いずれかのインボイスが挿入されるたびに、いずれかのテンプレート上で直接見ることができなかった、または編集可能でなかった式を有するセルを含む、過去のインボイスからのすべての式が、CopyByValuesパラメータによる静的値に分解されることになる。
デスティネーションシステムは、例示的な実施形態によれば、好ましくはすべてのデバイスプラットフォームに応答性があり、十分に適合し、HTMLおよびファイル伝送などのいくつかの標準ブラウザ特徴と統合される。デスティネーションシステムはまた、デスティネーションシステム内に含まれるデータがネイティブなapp経験でユーザによりアクセスされるように、デスティネーションシステムへの標準web-service APIアクセス方法を通じてネイティブappへ直接統合され得る。このような方法でのデータの提示は、ネイティブSDK環境または他の開発フレームワーク、例えば、Android Studio、Apple Xcode、Xamarin、またはCordovaでの付加的なコーディングを通じてデスティネーションシステムにより有効にされる。
ィネーションシステムサーバは、あるケースでは、ソフトウェア開発産業に典型的な数多くのフォーマットおよび方法のうちの1つを用いて、結果として生じるデスティネーションページに関するCSSおよびHTMLではなく異なる出力フォーマットを生成し得る。最後に、モバイルappは、HTMLメニューとは対照的に、モバイルプラットフォームにとって特異的および一貫しているページのメニューなどのいくつかのハードコード化されたユーザインターフェース要素を有し得る。このようなハードコード化されたユーザインターフェース要素は、データリストをフェッチするためのweb-service API呼び出しと、これらのデータリストを処理するためのモバイルapp内のハードコード化されたユーザインターフェースコードとの組み合わせであり得る。
携帯電話などの多くのデバイスは、多種多様な解像度の小さな画面を持っている。現代のフローベースレイアウトは、このような場合にユーザ経験を向上させることができる。webifierは、訪問者がブラウザ、ネイティブモバイルアプリケーション、またはその他の方法を使用しているかにかかわらず、訪問者の経験および/または画面スペースの使用を最適化するために、テンプレートシートをフローレイアウトに完全にまたは部分的に変換するために様々な方法を使用し得る。
るための親和性を有し得る。webifierは、垂直セクションまたは水平セクションを識別するために境界を分析し得る。例えば、境界が3つの水平に隣接するセルの周りにある場合、webifierは、それらのセル間をラッピングしないことに対して親和性を有し得、かつそれらのセルの前後の垂直スペースを増大させ得る。webifierは、テンプレート行が第1の列から始まる1つまたは複数の空のセルを左に有すると決定し得、その行にコンテンツを有する第1のセルが画面の左端に近づいてレンダリングされるように、それらの空のセルをスキップし得る。webifierは、いくつかの行が垂直セクション内にあり、コンテンツの左側に異なる数の空のセルを有していると決定し得、そのセクション内のすべての行について同じ数の空のセルを左側にスキップし得る。
いくつかの要求の多い使用シナリオでは、設計者は、レコードシートにおけるレコードの一次セット、並びに、各一次レコードに関する別のシートにおける1つまたは多くの“secondary records”を有することを望む場合があり、設計者は、例示的な実施形態によれば、レコードの一次セットの、伝統的なデータベースソフトウェアセンスのような“primary key”によって二次レコードを一次レコードに属するものとして識別することを意図する。手短に言えば、設計者は、一次レコードデータだけでなく二次レコードデータもポピュレートされるテンプレートシートを有するようにするために、レコードセット間で表される関係性を有することを意図し得る。例えば、1つのレコードシートは、列“company ID”および“company name”を有してよく、1つの行は、値に関する“1”および“Pleasant Solutions”を有する。第2のレコードシートは、列“company ID”および“specialization”を有してよく、1つの行は、“1”および“Software
Development Consultants”を有する。例示的な実施形態によれば、設計者が、“Pleasant Solutions”と“Software Development Consultants”との両方の記載を作成するテンプレートシートに基づいて詳細ページを表示することを望む場合、webifierシステムは、このような使用をサポートする。
例示的な実施形態によれば、ページのリストおよびそれらの共有パーミッションなどのデスティネーションシステムからの付加的な情報を有するまたは有さない、あらかじめ設計されたおよび/またはあらかじめ構成されたスプレッドシート定義を含むApp Templates全体を、設計者の所有するweb-appの開始点としてコピーするおよび使用するべく設計者のコミュニティから他の設計者ユーザへ利用可能であり得る(図22)。これらは、別々にリストすることもでき、app内のページタイプ、レコードシート上の列の名前、任意のセルの内容からのキーワード、存在する日付フィールドなどのセルフォーマット、並びに、どんな設計者が該App Template web-appを用いているかまたはどんな産業に設計者の雇用主が属しているかの関連性に基づく、目的、カテゴリ、産業、またはスマートサーチによりサーチ可能である。
スプレッドシートツール内のプラグインまたはAdd-Onは、クライアント-サーバアプリケーションモデルに関するソフトウェア開発産業に典型的な多くの方法で、デスティネーションシステムサーバと通信し、そのユーザインターフェースを表示し得る。例えば、図のいくつかは、デスティネーションシステムが主としてHTMLインターフェース、伝統的なウェブページを取得するためにweb-service API呼び出しを用いるAdd-Onの結果を例示し、例示的には、埋め込みブラウザウィンドウのように動作するフレームにおけるウェブページを示す。これは、Add-Onのユーザインターフェース要素の多くが再使用され、インストールされたAdd-Onを有さない設計者に関するデスティネーションシステムの管理ページ上のそれらのそれぞれのカウンターパートと概ね一致することを可能にする。セルの範囲を選択するのにマウスを用いる能力などの
Add-On内のいくつかの機能は、設計者が範囲をタイピングすることに限定するために制限、除去、または変更されてよく、または代替的に、デスティネーションシステム管理ページを有する埋め込みスプレッドシートツール上で行われ得る。簡略のため、Add-Onユーザインターフェースまたはデスティネーションシステム管理ページを表す添付図は、添付されていない場合であっても、それらのそれぞれのカウンターパートを有するとみなされるべきである。
Webifierは、多数のシートで動作し得、多くの種類のシートに同時に作用し得るため、シートの付加的な整理およびナビゲーションは、設計者にとって有益であり得る。webifierは、埋め込まれたスプレッドシートツールを有するデスティネーションシステムを有し得、また、外部スプレッドシートツールと統合されたAdd-Onも有し得る。以下の態様は、いずれかと同様に適用され得る。
のリストが表示される。webifierは、それが表すシートまたはグループの種類に基づいて、自動的にカラーコードおよび/またはその他の方法でタブの外観を変更し得る。
Webifierは、スプレッドシートツールとは別個のアプリケーションである必要はなく、外部アプリケーションにアクセス可能にされた手段を介するスプレッドシートツールとの通信に限定される必要はない。webifierは、代わりに、タイトな関係性を有してよく、それにより、これは、スプレッドシートツールとのより深いおよび/またはよりバックエンドベースのインテグレーションおよび通信チャネルを有し得る。これはまた、本明細書で「タイト・インテグレーション」と称され得る。
されたセルの内容を有する必要さえもない。セルの内容は、代わりに、1つのデータベーステーブルがセル書式設定のすべてを有し、異なるデータベーステーブルがセルの式を有し、第3のデータベーステーブルが、評価された式からのセルのキャッシュ値を有するように分割されてよい。さらに、データベーススキーマは、ユニークIDおよび式により簡単に定義される“units”のリストを有する1つまたは複数のデータベーステーブルを有し得るので、セルは、行および列に編成される必要はないかもしれず、スキーマはまた、データがよく知られたスプレッドシートとして設計者に提示されることになるまたは設計者がスプレッドシートフォームにおいてデータと一時的に対話しているときなどの選択的状況で、ユニットが行および列としてマップバックされることを可能にする別個の1つまたは複数のテーブルを有し得る。
システムは、“list item template”と同じテンプレートシートの方法を用いることができる。例えば、“List”のページタイプを作成することもでき
、この場合、入力および出力は、ユーザがその詳細を閲覧するのに行を選択することを必要とすること以外は、“details”ページタイプと同一となり、すべての行レコードは、リストフォームにおいて次々に表示されることになり、リスト上の各レコードは、アイテムテンプレートに従って表示される。レコードごとに情報のいくつかの行が必要とされるが、全詳細ページを保証するのに十分ではない場合、または詳細ページへの繰返しのナビゲーティングは望ましくないため、これは、例えば、行レコードリストが訪問者に表示されることを可能にする。
止する結果になる場合、ページ全体またはページの一部へのアクセスをブロックし得る。webifierは、アクセス違反を記録し、かつ/または管理者または設計者に通知を送信し得る。
例示的なユースケースによれば、設計者は、webifier Add-Onが既にインストールされている、Windowsデスクトップバージョンのスプレッドシートアプリケーション、例えば、MICROSOFT EXCELを開き得る。Add-Onは、スプレッドシートアプリケーションに埋め込まれたメインAdd-Onユーザインターフェースとして“Sidebar”を含み得る。設計者は、ログインすることを要求され得る(図13)。ログインの成功は、設計者を、以前に作成したweb-appのリストを有する図12へ連れていく。設計者は、スプレッドシートアプリケーションにより利用可能な普通の方法で新しいスプレッドシートファイルを作成し、次いで、図12で見られるようにアップロード矢印(サーバへのアップロード)をクリックし得る。設計者は、appの名前を設定し(図23)、ほぼ空のスプレッドシート(この例では)がサーバに送信され、ほぼ空のweb-appとなる。設計者は、次に、図18上のページの空リストを見て、図69のメニューを見るべくweb-appアクションメニュー上をクリックする、または図55のメニューを見るべくweb-app タブのアクションメニュー上をクリックする。ユーザは、該メニューからの追加ページをクリックし、図51のようなフォームへ進み、これは、ページ“Title”などのすべてのページタイプに共通のプロパティを表示してよく、また、所望のデスティネーションページタイプを選ぶべくドロップダウンを表示してよい。設計者は、次に、設計者のページタイプの選択に応じて、図26の(API)、27(Calendar)、29(Container)、33(CSV
Import)、35(Details Report)、38(Edit-Cells)、41(Edit-Record)、43(Insert)、45(Link)、46(PDF)、47(Report)、49(Tabs Container)に似ていてよい、ページタイプ設定および構成を定義することを要求する主としてブランクのフォ
ームを見ることになる。設計者は、それぞれ本明細書で説明される1つまたは複数の特徴を組み込んでいるページを必要なだけ作成するべくこのプロセスを繰り返し得る。
Claims (15)
- 少なくとも1つのウェブページを備える対話型ウェブアプリケーションを生成するためのコンピュータ実装方法であって、
スプレッドシート内の少なくとも1つの一次データソースを決定することであって、前記少なくとも1つの一次データソースが、前記スプレッドシートの第1のワークシートに対応する、前記決定することと、
少なくとも1つの二次データソースを決定することであって、前記少なくとも1つの二次データソースが前記第1のワークシートと異なる第2のワークシートに対応する、前記決定することと、
前記一次データソースのレコードと前記二次データソースのレコードとの間の関係を決定することであって、前記関係を決定することは、前記第1のワークシートおよび前記第2のワークシートの1つもしくは複数の特徴に基づいて、または前記一次データソースのレコードのコンテンツおよび前記二次データソースのレコードのコンテンツに基づいて、前記関係を自動的に検出することを含む、前記決定することと、
前記決定された関係に基づいて、前記一次データソースの前記レコードの少なくとも一部および前記二次データソースの前記レコードの少なくとも一部を備える第3のワークシートを自動的に生成することであって、ここにおいて、前記第3のワークシートのコンテンツは、前記第1のワークシートのコンテンツおよび前記第2のワークシートのコンテンツと同期され、ここにおいて、前記第3のワークシートの第1の行は、前記一次データソースから選択される少なくとも1つの第1のセル、ならびに、前記決定された関係および前記第1のセルに基づいて前記二次データソースから選択される少なくとも1つの、前記第1のセルと異なる第2のセルを備える、前記生成することと、
前記第3のワークシートのレコードを修正することによってユーザ入力を受信することと、
前記受信したユーザ入力に基づき、かつ前記決定された関係に基づいて、前記第3のワークシートの前記レコードに対応する前記二次データソースの少なくとも1つのレコードを更新することと、を含む、方法。 - 前記第3のワークシートが、前記一次データソースの前記レコードの少なくとも一部および前記二次データソースの前記レコードの少なくとも一部の冗長なコピーを含み、
前記冗長なコピーは、前記一次データソースの前記レコードの少なくとも一部または前記二次データソースの前記レコードの少なくとも一部への変更を検出したことに応答して自動的に更新される、請求項1に記載の方法。 - 前記スプレッドシート内の第1のユーザインターフェース・テンプレートを決定することであって、前記第1のユーザインターフェース・テンプレートは、前記一次データソースおよび前記二次データソースを識別する、前記決定すること、をさらに含み、
前記一次データソースのレコードと前記二次データソースのレコードとの間の関係を決定することは、さらに、前記第1のユーザインターフェース・テンプレートに基づく、請求項1または請求項2に記載の方法。 - 前記一次データソースのレコードの少なくとも一部または前記二次データソースのレコードの少なくとも一部のコンテンツが変更されたことを判定することに応答して、前記第3のワークシートの前記対応するコンテンツを更新することをさらに含む、請求項1~請求項3のいずれか1項に記載の方法。
- 前記第3のワークシートのコンテンツが変更されたことを判定することに応答して、前記一次データソースのレコードの少なくとも一部または前記二次データソースのレコードの少なくとも一部の対応するコンテンツを更新することをさらに含む、請求項1~請求項4のいずれか1項に記載の方法。
- 前記一次データソースの前記レコードと前記二次データソースの前記レコードとの間の前記関係を決定することが、
前記一次データソースの前記レコードと前記二次データソースの前記レコードとの間の前記関係の表示を含む第2のユーザ入力を受信することを含む、請求項1~請求項5のいずれか1項に記載の方法。 - 前記一次データソースの前記レコードと前記二次データソースの前記レコードとの間の前記関係を決定することが、
1つまたは複数の手がかりに基づいて、自動的に、前記一次データソースの前記レコードと前記二次データソースの前記レコードとの間の潜在的な関係を決定することと、
前記決定された潜在的関係の信頼性レベルを決定することと、
前記決定された信頼性レベルに基づいて前記決定された潜在的関係を受け入れるか、または拒否することと、を含む、請求項1~請求項5のいずれか1項に記載の方法。 - 前記一次データソースのレコードと前記二次データソースのレコードとの関係を決定することが、前記一次データソースの前記レコードおよび前記二次データソースの前記レコードのレコード構造に基づいている、請求項1~請求項5のいずれか1項に記載の方法。
- 前記一次データソースのレコードと前記二次データソースのレコードとの関係を決定することが、前記一次データソースの前記レコードの第1の列および前記二次データソースの前記レコードの第2の列の共通のコンテンツに基づいている、請求項1~請求項5のいずれか1項に記載の方法。
- 前記関係を決定することは、前記スプレッドシートのセルの少なくとも1つの式の少なくとも1つのパラメータに基づく、請求項1~請求項5のいずれか1項に記載の方法。
- 前記第3のワークシートの少なくとも1つの第1のレコードのフォーマットが変更されたことを判定することに応答して、前記第1のワークシートまたは前記第2のワークシートの対応する第2のレコードのフォーマットを更新すること、または
前記第1のワークシートまたは前記第2のワークシートの少なくとも1つの第1のレコードのフォーマットが変更されたことを判定することに応答して、前記第3のワークシートの対応する第2のレコードのフォーマットを更新すること、をさらに含む、請求項1~請求項10のいずれか1項に記載の方法。 - 前記スプレッドシート内の少なくとも1つの三次データソースを決定することであって、前記少なくとも1つの三次データソースが、前記スプレッドシートの異なる第4のワークシートに対応する、決定することと、
前記第3のワークシートの前記レコードと前記三次データソースのレコードとの間の第2の関係を決定することと、
前記決定された第2の関係に基づいて、前記第3のワークシートの前記レコードの少なくとも一部および前記三次データソースの前記レコードの少なくとも一部を備える第5のワークシートを自動的に生成することであって、前記第5のワークシートのコンテンツが、前記第1のワークシートのコンテンツ、前記第2のワークシートのコンテンツ、および前記第4のワークシートのコンテンツと同期される、生成することと、をさらに含む、請求項1~請求項11のいずれか1項に記載の方法。 - 前記第4のワークシートの少なくとも1つのセルは、自動的に生成された前記第3のワークシートの少なくとも1つのセルを参照する式を含む、請求項12に記載の方法。
- 請求項1~請求項13のいずれか1項に記載の方法を実行するよう構成されるコンピューティングデバイス。
- 1つまたは複数のプロセッサによって実行されるときに、請求項1~請求項13のいずれか1項に記載の方法のパフォーマンスを生じさせる命令を格納するコンピュータ可読媒体。
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/829,979 | 2017-12-03 | ||
US15/829,979 US10540153B2 (en) | 2016-12-03 | 2017-12-03 | Spreadsheet-based software application development |
PCT/CA2018/051547 WO2019104447A1 (en) | 2017-12-03 | 2018-12-03 | Spreadsheet-based software application development |
JP2020529683A JP7153725B2 (ja) | 2017-12-03 | 2018-12-03 | スプレッドシートに基づくソフトウェアアプリケーションの開発 |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020529683A Division JP7153725B2 (ja) | 2017-12-03 | 2018-12-03 | スプレッドシートに基づくソフトウェアアプリケーションの開発 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2022177302A JP2022177302A (ja) | 2022-11-30 |
JP7490729B2 true JP7490729B2 (ja) | 2024-05-27 |
Family
ID=66664371
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020529683A Active JP7153725B2 (ja) | 2017-12-03 | 2018-12-03 | スプレッドシートに基づくソフトウェアアプリケーションの開発 |
JP2022159385A Active JP7490729B2 (ja) | 2017-12-03 | 2022-10-03 | スプレッドシートに基づくソフトウェアアプリケーションの開発 |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020529683A Active JP7153725B2 (ja) | 2017-12-03 | 2018-12-03 | スプレッドシートに基づくソフトウェアアプリケーションの開発 |
Country Status (6)
Country | Link |
---|---|
EP (2) | EP3718000B1 (ja) |
JP (2) | JP7153725B2 (ja) |
CN (1) | CN111819534A (ja) |
CA (2) | CA3216654A1 (ja) |
PL (1) | PL3718000T3 (ja) |
WO (1) | WO2019104447A1 (ja) |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110413279B (zh) * | 2019-07-05 | 2023-11-03 | 中国平安财产保险股份有限公司 | 数据加载方法和装置 |
EP4058886A4 (en) | 2019-11-11 | 2023-12-13 | AVEVA Software, LLC | COMPUTER SYSTEM AND METHOD FOR A LOW-CODE/NO-CODE DISTRIBUTED COMPUTING ENVIRONMENT |
CN110989983B (zh) * | 2019-11-28 | 2022-11-29 | 深圳航天智慧城市系统技术研究院有限公司 | 一种零编码的应用软件快速构建系统 |
CN113779942B (zh) * | 2020-06-01 | 2023-08-18 | 腾讯科技(深圳)有限公司 | 一种表格数据处理方法、装置以及计算机可读存储介质 |
US11848976B2 (en) * | 2020-06-30 | 2023-12-19 | Oracle International Corporation | Custom action invocation in a speadsheet integrated with web services |
CN111723560B (zh) * | 2020-07-15 | 2024-04-19 | 金蝶软件(中国)有限公司 | 一种表格并行显示区域动态调整方法、系统及相关设备 |
CN112837565B (zh) * | 2021-01-20 | 2022-11-11 | 山东师范大学 | 一种散点图的多标签教学演示系统及方法 |
CN113361231B (zh) * | 2021-07-06 | 2024-05-28 | 北京字跳网络技术有限公司 | 信息引用方法、系统、装置和电子设备 |
CN113656032B (zh) * | 2021-08-23 | 2023-09-26 | 湖南快乐阳光互动娱乐传媒有限公司 | 一种h5制作平台的循环取值列表的处理方法及系统 |
CN113467764A (zh) * | 2021-09-02 | 2021-10-01 | 北京开物数智科技有限公司 | 基于规则引擎的规则计算方法及装置 |
CN114169303A (zh) * | 2021-12-14 | 2022-03-11 | 平安养老保险股份有限公司 | 基于vue.js的表格编辑方法、装置、设备及介质 |
CN114527969B (zh) * | 2022-01-25 | 2023-08-18 | 孚瑞肯电气(深圳)有限公司 | 一种可以将列表单元格转换成下拉列表形式输入的方法 |
CN114816186B (zh) * | 2022-05-09 | 2024-05-17 | 广州市易工品科技有限公司 | 基于移动端的报表设置方法、装置、电子设备及存储介质 |
CN117453268A (zh) * | 2023-12-26 | 2024-01-26 | 菲特(天津)检测技术有限公司 | 一种用于数据管理的快速开发平台 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005352634A (ja) | 2004-06-09 | 2005-12-22 | Hidenori So | Xmlを用いた分散データ処理システム |
US20070162840A1 (en) | 2004-11-19 | 2007-07-12 | Rochelle Jonathan P | Converting spreadsheet applications to web-based applications |
JP2008140194A (ja) | 2006-12-01 | 2008-06-19 | Internatl Business Mach Corp <Ibm> | コンピュータ用アプリケーション・プログラムの作成システム、方法、及びプログラム |
JP2011502303A (ja) | 2007-10-25 | 2011-01-20 | マイクロソフト コーポレーション | リアルタイムコラボレーションの間のデータ及びローカル計算のプライベートビュー |
US20120110428A1 (en) | 2010-11-03 | 2012-05-03 | Microsoft Corporation | Spreadsheet model for distributed computations |
US20150339106A1 (en) | 2014-05-21 | 2015-11-26 | InvestCloud Inc. | Tabular format transaction editor |
Family Cites Families (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AU2001277868A1 (en) * | 2000-07-11 | 2002-01-21 | Juice Software, Inc. | A method and system for integrating network-based functionality into productivity applications and documents |
US20040103365A1 (en) * | 2002-11-27 | 2004-05-27 | Alan Cox | System, method, and computer program product for an integrated spreadsheet and database |
US7523395B1 (en) * | 2003-05-30 | 2009-04-21 | Oracle International Corporation | Web application generator for spreadsheet calculators |
US20050268215A1 (en) * | 2004-06-01 | 2005-12-01 | Microsoft Corporation | Method and apparatus for viewing and interacting with a spreadsheet from within a web browser |
US7617451B2 (en) * | 2004-12-20 | 2009-11-10 | Microsoft Corporation | Structuring data for word processing documents |
CN101542457B (zh) * | 2005-04-29 | 2015-11-25 | 微软技术许可有限责任公司 | 事务变换 |
US7752536B2 (en) * | 2005-09-09 | 2010-07-06 | Microsoft Corporation | Designating, setting and discovering parameters for spreadsheet documents |
US20140006913A1 (en) * | 2007-12-21 | 2014-01-02 | Adobe Systems Incorporated | Visual template extraction |
US20110088011A1 (en) * | 2009-10-14 | 2011-04-14 | Vermeg Sarl | Automated Enterprise Software Development |
US20110106835A1 (en) * | 2009-10-29 | 2011-05-05 | International Business Machines Corporation | User-Defined Profile Tags, Rules, and Recommendations for Portal |
US9053083B2 (en) * | 2011-11-04 | 2015-06-09 | Microsoft Technology Licensing, Llc | Interaction between web gadgets and spreadsheets |
US20130145244A1 (en) * | 2011-12-05 | 2013-06-06 | Microsoft Corporation | Quick analysis tool for spreadsheet application programs |
CA2862387C (en) * | 2011-12-29 | 2023-03-14 | Michael J. Chen | Spreadsheet-based programming language adapted for report generation |
US9665349B2 (en) * | 2012-10-05 | 2017-05-30 | Box, Inc. | System and method for generating embeddable widgets which enable access to a cloud-based collaboration platform |
JP2014153751A (ja) * | 2013-02-05 | 2014-08-25 | Shuichi Kuroki | データの抽出・編集・出力装置及びそのプログラム |
US20140236860A1 (en) * | 2013-02-19 | 2014-08-21 | Ray Camrass | system allowing banks to diversify their loan portfolios via exchanging loans |
CN105122238B (zh) * | 2013-05-22 | 2018-11-27 | 谷歌有限责任公司 | 协作文档中的非协作过滤器 |
JP2016091244A (ja) | 2014-10-31 | 2016-05-23 | 富士通エフ・アイ・ピー株式会社 | 情報処理装置、プログラム |
US9910843B2 (en) * | 2015-02-03 | 2018-03-06 | Intuit Inc. | Systems, methods and articles for a web-based spreadsheet application |
KR101769857B1 (ko) * | 2015-12-28 | 2017-08-22 | (주)비아이매트릭스 | 스프레드시트 인터페이스를 이용한 데이터베이스 갱신 시스템 |
-
2018
- 2018-12-03 PL PL18883752.0T patent/PL3718000T3/pl unknown
- 2018-12-03 CA CA3216654A patent/CA3216654A1/en active Pending
- 2018-12-03 JP JP2020529683A patent/JP7153725B2/ja active Active
- 2018-12-03 WO PCT/CA2018/051547 patent/WO2019104447A1/en unknown
- 2018-12-03 EP EP18883752.0A patent/EP3718000B1/en active Active
- 2018-12-03 CA CA3084152A patent/CA3084152C/en active Active
- 2018-12-03 CN CN201880078270.0A patent/CN111819534A/zh active Pending
- 2018-12-03 EP EP23171520.2A patent/EP4231137A1/en active Pending
-
2022
- 2022-10-03 JP JP2022159385A patent/JP7490729B2/ja active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005352634A (ja) | 2004-06-09 | 2005-12-22 | Hidenori So | Xmlを用いた分散データ処理システム |
US20070162840A1 (en) | 2004-11-19 | 2007-07-12 | Rochelle Jonathan P | Converting spreadsheet applications to web-based applications |
JP2008140194A (ja) | 2006-12-01 | 2008-06-19 | Internatl Business Mach Corp <Ibm> | コンピュータ用アプリケーション・プログラムの作成システム、方法、及びプログラム |
JP2011502303A (ja) | 2007-10-25 | 2011-01-20 | マイクロソフト コーポレーション | リアルタイムコラボレーションの間のデータ及びローカル計算のプライベートビュー |
US20120110428A1 (en) | 2010-11-03 | 2012-05-03 | Microsoft Corporation | Spreadsheet model for distributed computations |
US20150339106A1 (en) | 2014-05-21 | 2015-11-26 | InvestCloud Inc. | Tabular format transaction editor |
Also Published As
Publication number | Publication date |
---|---|
EP3718000A1 (en) | 2020-10-07 |
CA3216654A1 (en) | 2019-06-06 |
WO2019104447A1 (en) | 2019-06-06 |
EP3718000B1 (en) | 2023-06-07 |
JP2022177302A (ja) | 2022-11-30 |
CA3084152A1 (en) | 2019-06-06 |
JP7153725B2 (ja) | 2022-10-14 |
EP4231137A1 (en) | 2023-08-23 |
EP3718000A4 (en) | 2021-09-01 |
CA3084152C (en) | 2023-10-17 |
CN111819534A (zh) | 2020-10-23 |
PL3718000T3 (pl) | 2024-02-05 |
JP2021505998A (ja) | 2021-02-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP7460689B2 (ja) | スプレッドシートに基づくソフトウェアアプリケーション開発 | |
JP7490729B2 (ja) | スプレッドシートに基づくソフトウェアアプリケーションの開発 | |
US11113041B2 (en) | Spreadsheet-based software application development | |
JP2021028828A6 (ja) | スプレッドシートに基づくソフトウェアアプリケーション開発 | |
US11726753B2 (en) | Spreadsheet-based software application development | |
AU2021201489B2 (en) | System and Process for generating an internet application | |
US11783120B2 (en) | System and process for generating an internet application |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20221003 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20230817 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20230907 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20231205 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20240201 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20240227 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20240321 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20240422 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20240515 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 7490729 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |