Coder Social home page Coder Social logo

gettingstarted's Introduction

Project management – Software Development Project

« OpenCompare and configurable HTML export »

1. Objectives

Opencompare.org has for objectives to help a community of users to import, edit, view and use array of products in a given domain.

The purpose of this project is to generate, from a comparison matrix template, an HTML representation. This export is highly configurable because we want to handle different graphic aspects of the matrix, for example the ability to:

  • add colors on the headers of the features
  • add colors on certain types of value (color "yes" boolean value in green)
  • reverse the matrix (the products are displayed at the top instead of being displayed on the left side)

In terms of web technology, it uses HTML5, CSS and Javascript. The solutions runs on any devices (cellphones, tablets, computers, etc ...). The procedure takes as input a comparison matrix, some configuration items an generates tatically a set of HTML, CSS and Javascript files. The result is usable on any browser.

2. Result

Since the beginning of the project, we had developed several things. Indeed, firstly we had created 2 classes : Param and DataStyle. Objects of Param class contains a collection of DataStyle. This class permits to get JSON data with information for the coloration of the text or the background notably, from a JSON file created by us. For one JSON file, there are several DataStyle created owned to this structure. Param also contains attributes for describe the matrix; if the name of the PCM is shown, or if the features's name are shown. Those classes are used in an other class, CSSExporter - the second point developed, for the generation of css files. CSSExporter use Genesis librairy too.

Thirdly, we had developed HTMLExporterCustom, which looks like HTMLExporter, already in the project. Used for the generation of HTML file, and the creation of the matrix from OpenCompare. Param class is an attribute in this class. Param permits here to put some coloration on the matrix, and on specific data, and also to change the look of the matrix. Futhermore, the exportation is working, the CSS file and the HTML file are generated in an archive zip.

Functions had been developed to change matrix's aspect. Now, there is the possibility to reverse the matrix, and the products are at the bottom of the matrix, and the features are on the left. The name of the matrix can be show or not. If the matrix is big, the user can show the feature at the bottom of it. We can applied a sort by increasing or decreasing order on feature. Still on features, but with products too, functions rangein and rangeout permits to show data in accordance with a gap or with an exact value.

3. License

The project OpenCompare was, before the beginning of this project, accessible here and was provide with an Apache license file. The export process with follow the same license. To know more about it, you can read the license file here.

4. Technologies used

During this project, we worked on several technologies and several languages. In the one hand, the languages. Java was the base of our development process. It handles the back-end with the current management of the OpenCompare project. It is used to generate the custom parameters of the user in a JSON file and to create an archive to put all the files in. Then, the objective of the project was to generate HTML and CSS file so we handle those languages too. Finally, we used Markdown to maintain and update the current documentation.

In the other hand, the technologies. To improve the productivity of all the developement team, IntelliJ was the chosen integrated development environment. It permits to handle easily the Maven project and it provides an internal VCS. Concretely, Maven was the most useful tool during this project. It manages goodly the dependencies and avoid some library version problems. To parse the JSON, we did it manually. We were thinking about using the JSOUP library but it wasn't working like we would like to. For the CSS, we used the GENESIS library. It creates CSS "module" to generate CSS classes thanks to a JSON parameter/file. It's powerful and easily maintanable. Then, we prefered JUnit to Mockito for the tests management because we seen it during our courses.

We would like to add something about this. We know that we could automate tasks with Travis (which is already implemented in the project with its .travis.yml) but nobody of the team knew to use it or was able to implement it. The lack of time prevented us from using this tool that could, it's true, save us time.

5. Project architecture

  • idea/
    • Some files of the IDE we use (IntelliJ)
  • pcms/
    • PCM1
      • info1.txt
      • param1.json
      • param2.json
      • param3.json
      • param4.json
      • tesssvtttt369852147.pcm
    • PCM2
      • alternative-parsers-mediawiki.pcm
      • info2.txt
      • param1.json
      • param2.json
      • param3.json
      • param4.json
    • PCM3
      • index1.html
      • info3.txt
      • param1.json
      • param2.json
      • param3.json
      • param4.json
      • test-matrice-simple.pcm
    • PCM4
      • info4.txt
      • param1.json
      • param2.json
      • param3.json
      • param4.json
      • style1.css
      • style2.css
      • style3.css
      • style4.css
      • comparison-nikon-dslr.pcm
    • TEST
      • TESTCSS
        • style1.css
        • style2.css
        • style3.css
        • style4.css
      • info1.txt
      • param1.json
      • param2.json
      • param3.json
      • param4.json
      • tesssvtttt369852147.pcm
  • src/
    • main/
      • java/
        • org/
          • opencompare/
            • CSSExporter.java
            • DataStyle.java
            • HTMLExporterCustom.java
            • MyPCMPrinter.java
            • Param.java
    • test/
      • java/
        • org/
          • opencompare/
            • MyPCMPrinterTest.java
            • TestExport.java
            • TestParam.java
    • HTMLGenerated.html
    • style.css
  • target/
    • classes/
      • org/
        • opencompare/
          • CSSExporter.class
          • DataStyle.class
          • HTMLExporterCustom.class
          • MyPCMPrinter.class
          • Param.class
    • generated-sources/
      • annotations/
    • generated-test-sources/
      • test-annotations/
    • test-classes/
      • org/
        • opencompare/
          • TestMyPCMPrinter.class
          • TestExport.class
  • .gitignore
  • .travis.yml
  • getting-started.iml
  • LICENSE
  • pom.xml
  • README.md

6. Deployment instructions

From the beginning of the project, we were told that, if the project was going well, it could be possible to integrate our work to the OpenCompare project. To do this, it will be necessary to develop an interface which will permits to the user to customize the matrix. It wasn't included in the things asked to this part of the work. When the user will submit his customization, the back-end will have to generate the JSON file corresponding to the parameters. Then, our main will get it and generate the files. The server will juste have to send thoses files to the user.

7. Versioning

  • 1.0 : First functional release with export of two files (HTML+CSS) separately
  • 1.1 : Add reverse matrice feature and some test files
  • 1.2 : Correct some bug test and it exports in an archive
  • 1.3 : Improve the design of the resulting table of the export operation

gettingstarted's People

Contributors

cheisda avatar quentin29200 avatar testpersonal avatar ku-roe avatar gigouni avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.