ebook img

Visual Studio Lightswitch 2015, 2nd Edition: Create business applications easily, quickly, and eff ectively PDF

859 Pages·2015·155.19 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Visual Studio Lightswitch 2015, 2nd Edition: Create business applications easily, quickly, and eff ectively

L BOOKS FOR PROFESSIONALS BY PROFESSIONALS® THE EXPERT’S VOICE® IN .NET e u n g Visual Studio LightSwitch 2015 V Visual Studio In this fully updated second edition, award-winning author Tim Leung explains how to build i data-centric business applications for the desktop, cloud, web, and mobile devices in just a s few clicks, with no code required using Visual Studio Lightswitch 2015. This book explains the u basics of Visual Studio Lightswitch 2015 plus new features and key advanced topics that every Microsoft developer needs to know to create modern data services and build clients that can a LightSwitch 2015 run on multiple devices. l Visual Studio LightSwitch 2015 is a rapid application deployment tool that simplifies and S shortens the time needed to develop business applications. The basics are very easily understood but more advanced users will hunger for more. How do you design complex t layouts? How do you query data using LINQ and other syntax structures? How do you secure u your application against malicious use? Visual Studio LightSwitch 2015 answers these questions d and more as author Tim Leung—winner of a Microsoft 2011 Community Contributor Award for Create business applications easily, his LightSwitch expertise—covers this breakthrough product in detail. For serious developers i building, enhancing, and deploying advanced business applications using LightSwitch makes o quickly, and eff ectively sense because they can benefit from the elegance, convenience, and cost savings afforded by rapid application development before going beyond the “click-and-you’re-done” interface to L — include the extra value and depth of coding expertise that their clients value. i g Second Edition h — t S Tim Leung w i t c h 2 0 1 ISBN 978-1-4842-0767-3 Shelve in: 55999 .Net 5 User level: Beginning–Advanced 9781484207673 SOURCE CODE ONLINE www.apress.com www.it-ebooks.info Visual Studio LightSwitch 2015 Second Edition Tim Leung www.it-ebooks.info Visual Studio LightSwitch 2015 Copyright © 2015 by Tim Leung This work is subject to copyright. All rights are reserved by the Publisher, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, reuse of illustrations, recitation, broadcasting, reproduction on microfilms or in any other physical way, and transmission or information storage and retrieval, electronic adaptation, computer software, or by similar or dissimilar methodology now known or hereafter developed. Exempted from this legal reservation are brief excerpts in connection with reviews or scholarly analysis or material supplied specifically for the purpose of being entered and executed on a computer system, for exclusive use by the purchaser of the work. Duplication of this publication or parts thereof is permitted only under the provisions of the Copyright Law of the Publisher’s location, in its current version, and permission for use must always be obtained from Springer. Permissions for use may be obtained through RightsLink at the Copyright Clearance Center. Violations are liable to prosecution under the respective Copyright Law. ISBN-13 (pbk): 978-1-4842-0767-3 ISBN-13 (electronic): 978-1-4842-0766-6 Trademarked names, logos, and images may appear in this book. Rather than use a trademark symbol with every occurrence of a trademarked name, logo, or image we use the names, logos, and images only in an editorial fashion and to the benefit of the trademark owner, with no intention of infringement of the trademark. The use in this publication of trade names, trademarks, service marks, and similar terms, even if they are not identified as such, is not to be taken as an expression of opinion as to whether or not they are subject to proprietary rights. While the advice and information in this book are believed to be true and accurate at the date of publication, neither the authors nor the editors nor the publisher can accept any legal responsibility for any errors or omissions that may be made. The publisher makes no warranty, express or implied, with respect to the material contained herein. Managing Director: Welmoed Spahr Lead Editor: James DeWolf Development Editor: Douglas Pundick Technical Reviewer: Fabio Claudio Ferracchiati Editorial Board: Steve Anglin, Pramila Balen, Louise Corrigan, Jim DeWolf, Jonathan Gennick, Robert Hutchinson, Celestin Suresh John, Michelle Lowman, James Markham, Susan McDermott, Matthew Moodie, Jeffrey Pepper, Douglas Pundick, Ben Renow-Clarke, Gwenan Spearing Coordinating Editor: Melissa Maldonado Copy Editor: April Rondeau Compositor: SPi Global Indexer: SPi Global Artist: SPi Global Distributed to the book trade worldwide by Springer Science+Business Media New York, 233 Spring Street, 6th Floor, New York, NY 10013. Phone 1-800-SPRINGER, fax (201) 348-4505, email [email protected], or visit www.springer.com. Apress Media, LLC is a California LLC and the sole member (owner) is Springer Science + Business Media Finance Inc (SSBM Finance Inc). SSBM Finance Inc is a Delaware corporation. For information on translations, please email [email protected], or visit www.apress.com. Apress and friends of ED books may be purchased in bulk for academic, corporate, or promotional use. eBook versions and licenses are also available for most titles. For more information, reference our Special Bulk Sales–eBook Licensing web page at www.apress.com/bulk-sales. Any source code or other supplementary material referenced by the author in this text is available to readers at www.apress.com. For detailed information about how to locate your book’s source code, go to www.apress.com/source-code/. www.it-ebooks.info Contents at a Glance About the Author ��������������������������������������������������������������������������������������������������xxiii About the Technical Reviewers �����������������������������������������������������������������������������xxv Acknowledgments �����������������������������������������������������������������������������������������������xxvii Introduction ����������������������������������������������������������������������������������������������������������xxix ■ Part I: Introducing LightSwitch ����������������������������������������������������������1 ■ Chapter 1: Introducing LightSwitch �����������������������������������������������������������������������3 ■ Chapter 2: Setting Up Your Data ��������������������������������������������������������������������������15 ■ Chapter 3: Building HTML Applications ���������������������������������������������������������������43 ■ Chapter 4: Creating Desktop Applications �����������������������������������������������������������73 ■ Part II: Working with Data ��������������������������������������������������������������111 ■ Chapter 5: Quer ying Your Data ��������������������������������������������������������������������������113 ■ Chapter 6: Writing Data-Access Code����������������������������������������������������������������129 ■ Chapter 7: Validating Data ���������������������������������������������������������������������������������167 ■ Part III: Writing ScreenCode �����������������������������������������������������������201 ■ Chapter 8: Refinining HTML Clients Screens with JavaScript/CSS ��������������������203 ■ Chapter 9: Enhancing Desktop Screens with �NET Code ������������������������������������259 ■ Part IV: Refining Your Application ��������������������������������������������������303 ■ Chapter 10: Searching Data �������������������������������������������������������������������������������305 ■ Chapter 11: Building Practical Application Features �����������������������������������������329 iii www.it-ebooks.info ■ Contents at a GlanCe ■ Chapter 12: Supporting Multiple Languages �����������������������������������������������������387 ■ Chapter 13: Creating and Using Custom Controls ���������������������������������������������407 ■ Part V: Extending the Reach of Your Data ���������������������������������������441 ■ Chapter 14: Optimizing Data Connectivity with RIA Services ���������������������������443 ■ Chapter 15: Sharing Data with OData ����������������������������������������������������������������465 ■ Part VI: Getting Data Out �����������������������������������������������������������������483 ■ Chapter 16: Creating Reports ����������������������������������������������������������������������������485 ■ Chapter 17: Generating Office Documents ���������������������������������������������������������521 ■ Chapter 18: Sending Email ��������������������������������������������������������������������������������561 ■ Part VII: Extending LightSwitch ������������������������������������������������������591 ■ Chapter 19: Creating Control Extensions �����������������������������������������������������������593 ■ Chapter 20: Creating Data and Presentation Extensions �����������������������������������655 ■ Part VIII: Securing Your Application �����������������������������������������������735 ■ Chapter 21: Authenticating Your Users �������������������������������������������������������������737 ■ Chapter 22: Authorizing Your Users ������������������������������������������������������������������751 ■ Part IX: Going Live with Your Application ���������������������������������������777 ■ Chapter 23: Deploying Applications ������������������������������������������������������������������779 ■ Appendix A: Culture Names �������������������������������������������������������������������������������811 ■ Appendix B: Data Type Identifiers����������������������������������������������������������������������817 ■ Appendix C: Using Properties in Custom Controls ���������������������������������������������819 ■ Appendix D: Custom Screen Template View IDs �����������������������������������������������823 ■ Appendix E: Data Schemas ��������������������������������������������������������������������������������827 Index ���������������������������������������������������������������������������������������������������������������������841 iv www.it-ebooks.info Contents About the Author ��������������������������������������������������������������������������������������������������xxiii About the Technical Reviewers �����������������������������������������������������������������������������xxv Acknowledgments �����������������������������������������������������������������������������������������������xxvii Introduction ����������������������������������������������������������������������������������������������������������xxix ■ Part I: Introducing LightSwitch ����������������������������������������������������������1 ■ Chapter 1: Introducing LightSwitch �����������������������������������������������������������������������3 What’s New in 2015 ���������������������������������������������������������������������������������������������������������3 Understanding LightSwitch’s Architecture �����������������������������������������������������������������������4 The Data Tier ������������������������������������������������������������������������������������������������������������������������������������������5 The Logic Tier �����������������������������������������������������������������������������������������������������������������������������������������5 The Presentation Tier ������������������������������������������������������������������������������������������������������������������������������6 Introducing the Model-Centric Architecture ���������������������������������������������������������������������8 Building Your Application ��������������������������������������������������������������������������������������������������9 Understanding MVVM (Model-View-ViewModel) ������������������������������������������������������������10 Walkthrough: Creating a LightSwitch Project �����������������������������������������������������������������10 Summary ������������������������������������������������������������������������������������������������������������������������13 ■ Chapter 2: Setting Up Your Data ��������������������������������������������������������������������������15 Choosing Where to Store Your Data ��������������������������������������������������������������������������������15 What Are Entities and Properties? ����������������������������������������������������������������������������������16 Creating Tables (Entities) ������������������������������������������������������������������������������������������������16 v www.it-ebooks.info ■ Contents Creating Fields (Properties) ��������������������������������������������������������������������������������������������18 Storing Textual Data ������������������������������������������������������������������������������������������������������������������������������18 Storing Numbers (Double and Decimal Types) �������������������������������������������������������������������������������������19 Storing Numbers (Integer Types) ����������������������������������������������������������������������������������������������������������19 Formatting Numeric Fields �������������������������������������������������������������������������������������������������������������������19 Storing Images �������������������������������������������������������������������������������������������������������������������������������������21 Storing Binary Data ������������������������������������������������������������������������������������������������������������������������������21 Storing Dates ���������������������������������������������������������������������������������������������������������������������������������������21 Ensuring Unique Values ������������������������������������������������������������������������������������������������������������������������22 Changing Data Types ����������������������������������������������������������������������������������������������������������������������������22 Using LightSwitch Business Types ���������������������������������������������������������������������������������23 Storing Email Addresses �����������������������������������������������������������������������������������������������������������������������23 Storing Monetary Values �����������������������������������������������������������������������������������������������������������������������23 Storing Phone Numbers ������������������������������������������������������������������������������������������������������������������������25 Storing Web Addresses and Percentage Values �����������������������������������������������������������������������������������26 Storing People Data ������������������������������������������������������������������������������������������������������������������������������26 Examining What Happens in SQL Server ������������������������������������������������������������������������26 Creating Choice Lists ������������������������������������������������������������������������������������������������������27 Choice List Versus Related Tables ��������������������������������������������������������������������������������������������������������28 Defining Relationships ���������������������������������������������������������������������������������������������������28 Defining One-to-Many-Type Relationships �������������������������������������������������������������������������������������������29 How Relationships Are Defined in SQL Server ��������������������������������������������������������������������������������������30 Defining Self-Referencing Relationships ����������������������������������������������������������������������������������������������31 Defining Many-to-Many Relationships �������������������������������������������������������������������������������������������������31 Determining How Child Records Are Deleted ���������������������������������������������������������������������������������������32 Attaching Existing Data ��������������������������������������������������������������������������������������������������32 Attaching to an Existing Database ��������������������������������������������������������������������������������������������������������34 Attaching to SharePoint Data����������������������������������������������������������������������������������������������������������������36 Deleting a Data Source �������������������������������������������������������������������������������������������������������������������������37 Defining Relationships between Data Sources �������������������������������������������������������������������������������������37 vi www.it-ebooks.info ■ Contents Creating Computed Properties ���������������������������������������������������������������������������������������37 Creating Summary Properties ����������������������������������������������������������������������������������������37 Calculating Dates with Computed Properties ���������������������������������������������������������������������������������������38 Summarizing Child Records with Computed Properties �����������������������������������������������������������������������39 Returning Images with Computed Properties ���������������������������������������������������������������������������������������40 Sorting and Filtering by Computed Properties ��������������������������������������������������������������������������������������41 Summary ������������������������������������������������������������������������������������������������������������������������41 ■ Chapter 3: Building HTML Applications ���������������������������������������������������������������43 Building an HTML Application�����������������������������������������������������������������������������������������43 Creating Screens ����������������������������������������������������������������������������������������������������������������������������������43 Walkthrough 3-1� Creating an Application ��������������������������������������������������������������������������������������������45 Using the Screen Designer ���������������������������������������������������������������������������������������������53 Understanding Top-Level Screen Layout ����������������������������������������������������������������������������������������������53 Using the Screen Designer Toolbar �������������������������������������������������������������������������������������������������������55 Using Tabs �������������������������������������������������������������������������������������������������������������������������������������������55 Laying Out Your Screen with Group Controls ������������������������������������������������������������������56 Using Data Controls ��������������������������������������������������������������������������������������������������������58 Showing/Editing String Values��������������������������������������������������������������������������������������������������������������58 Working with Boolean Values ���������������������������������������������������������������������������������������������������������������60 Showing/Editing Date Values ����������������������������������������������������������������������������������������������������������������60 Showing/Editing Email or Web Addresses ��������������������������������������������������������������������������������������������61 Showing Lists of Records ���������������������������������������������������������������������������������������������������������������������61 Using Data Picker Controls �������������������������������������������������������������������������������������������������������������������64 Positioning Controls �������������������������������������������������������������������������������������������������������64 Setting Screen Properties ����������������������������������������������������������������������������������������������66 Building a Navigation Structure �������������������������������������������������������������������������������������67 Setting a Home Screen �������������������������������������������������������������������������������������������������������������������������67 Configuring the Navigation Menu ���������������������������������������������������������������������������������������������������������68 Navigating to Different Screens �����������������������������������������������������������������������������������������������������������69 vii www.it-ebooks.info ■ Contents Adding Navigation Buttons �������������������������������������������������������������������������������������������������������������������70 Changing Button Icons��������������������������������������������������������������������������������������������������������������������������70 Summary ������������������������������������������������������������������������������������������������������������������������71 ■ Chapter 4: Creating Desktop Applications �����������������������������������������������������������73 What This Chapter Covers ����������������������������������������������������������������������������������������������73 What Are the Benefits of Desktop Applications? ������������������������������������������������������������74 Creating a Desktop Client �����������������������������������������������������������������������������������������������75 Setting the Application Type �����������������������������������������������������������������������������������������������������������������75 Choosing a Screen Template ������������������������������������������������������������������������������������������76 Walkthrough 4-1� Creating New Data Screens ���������������������������������������������������������������77 Designing Screens ���������������������������������������������������������������������������������������������������������78 Setting Screen Properties ���������������������������������������������������������������������������������������������������������������������80 Grouping and Laying Out Controls ��������������������������������������������������������������������������������������������������������80 Choosing Data Controls ������������������������������������������������������������������������������������������������������������������������82 Displaying Data Using Data-Item Containers ����������������������������������������������������������������������������������������84 Using Data-Selection Controls ���������������������������������������������������������������������������������������85 Using the Auto-Complete Box Control ��������������������������������������������������������������������������������������������������86 Using the Modal Window Picker Control �����������������������������������������������������������������������������������������������87 Displaying Static Text and Images ����������������������������������������������������������������������������������88 Setting Control Appearances ������������������������������������������������������������������������������������������88 Positioning Control Labels ��������������������������������������������������������������������������������������������������������������������90 Styling Labels and Static Text Controls �������������������������������������������������������������������������������������������������91 Making Controls Read-Only ������������������������������������������������������������������������������������������������������������������92 Including Related Data Items �����������������������������������������������������������������������������������������93 Using the Data Grid and Data List Controls ��������������������������������������������������������������������94 Creating an Editable Grid Screen �����������������������������������������������������������������������������������95 Configuring Data Grid Settings �������������������������������������������������������������������������������������������������������������96 Setting Data Grid Header Buttons ���������������������������������������������������������������������������������������������������������98 Creating a List and Details Screen �������������������������������������������������������������������������������100 Creating a Search Screen ���������������������������������������������������������������������������������������������101 viii www.it-ebooks.info ■ Contents Creating Details Screens ����������������������������������������������������������������������������������������������102 Walkthrough 4-2� Using Details Screens ��������������������������������������������������������������������������������������������103 Setting Application Properties ��������������������������������������������������������������������������������������106 Configuring Screen Navigation �������������������������������������������������������������������������������������107 Designing Screens at Runtime �������������������������������������������������������������������������������������108 Reducing Project Sizes �������������������������������������������������������������������������������������������������109 Summary ����������������������������������������������������������������������������������������������������������������������109 ■ Part II: Working with Data ��������������������������������������������������������������111 ■ Chapter 5: Quer ying Your Data ��������������������������������������������������������������������������113 Introduction to Data Retrieval ���������������������������������������������������������������������������������������113 LightSwitch Queries Always Return Entities ���������������������������������������������������������������������������������������113 Understanding the Query Pipeline ��������������������������������������������������������������������������������114 Using LightSwitch’s Default Queries ����������������������������������������������������������������������������115 Filtering and Sorting data ���������������������������������������������������������������������������������������������116 Creating Queries Based on Entities ����������������������������������������������������������������������������������������������������116 Applying Filters �����������������������������������������������������������������������������������������������������������������������������������117 Comparing Against Other Fields/Properties ����������������������������������������������������������������������������������������119 Passing Arguments into a Query ��������������������������������������������������������������������������������������������������������120 Filtering by Global Values �������������������������������������������������������������������������������������������������������������������120 Modifying Screen Queries ������������������������������������������������������������������������������������������������������������������121 Sorting Data �����������������������������������������������������������������������������������������������������������������121 Sorting Data Grids in Desktop Applications ����������������������������������������������������������������������������������������122 Examining User-Setting Files ��������������������������������������������������������������������������������������������������������������123 Walkthrough: Working with Queries �����������������������������������������������������������������������������124 5-1� Filtering Controls �������������������������������������������������������������������������������������������������������������������������124 5-2� Using Queries on Screens �����������������������������������������������������������������������������������������������������������126 Summary ����������������������������������������������������������������������������������������������������������������������127 ix www.it-ebooks.info

Description:
In this fully updated second edition, award-winning author Tim Leung explains how to build data-centric business applications for the desktop, cloud, web, and mobile devices in just a few clicks - with no code required - using Visual Studio Lightswitch 2015. This book explains the basics of Visual S
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.