zaaReloaded2/zaaReloaded2/Controller/Elements/ElementBase.cs

60 lines
2.0 KiB
C#
Raw Normal View History

2015-07-13 21:57:35 +00:00
/* ElementBase.cs
2015-07-04 10:09:39 +00:00
* part of zaaReloaded2
*
2017-02-23 15:44:07 +00:00
* Copyright 2015-2017 Daniel Kraus
2015-07-04 10:09:39 +00:00
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
2015-07-13 21:57:35 +00:00
using Microsoft.Office.Interop.Word;
2015-07-06 13:48:43 +00:00
using zaaReloaded2.LabModel;
using System.Runtime.Serialization;
2015-07-04 10:09:39 +00:00
namespace zaaReloaded2.Controller.Elements
2015-07-04 10:09:39 +00:00
{
2015-07-13 21:57:35 +00:00
/// <summary>
/// Base class for formatting elements.
/// </summary>
public abstract class ElementBase : ICloneable
2015-07-04 10:09:39 +00:00
{
/// <summary>
2015-07-13 21:57:35 +00:00
/// Returns the label for this formatting element.
2015-07-04 10:09:39 +00:00
/// </summary>
2015-07-13 21:57:35 +00:00
abstract public string Label { get; }
/// <summary>
/// Executes the action described by this formatting element.
/// For example, an Items element Writes the laboratory items
/// listed in its Line property to a Word document.
2015-07-13 21:57:35 +00:00
/// </summary>
/// <param name="formatter">Formatter object that this
/// Element belongs to. The Formatter object provides access
/// to the current Word document etc.</param>
abstract public void Run(zaaReloaded2.Formatter.Formatter formatter);
public object Clone()
{
return CreateInstance();
}
/// <summary>
/// Creates a new instance that can be used for cloning.
/// </summary>
/// <returns>New instance of a derived class.</returns>
protected abstract ElementBase CreateInstance();
2015-07-04 10:09:39 +00:00
}
}